postRequestForQuotation
postRequestForQuotation
Path Parameters
- api-endpoint uuid required
The API endpoint to send a request for quotation to a manufacturer.
- application/json
Request Body
- filter string required
The filter to use.
Responses
- 200
- 401
- 402
- 403
- 404
The request was successful.
- application/json
- Schema
- Example (from schema)
Schema
rfqIdentification object
rfqConfiguration object
rfqSender object
cxHeader object
{
"rfqIdentification": {
"rfqSource": "string",
"rfqId": "string",
"rfqName": "string",
"rfqDateTime": "string",
"rfqVersion": "string"
},
"rfqConfiguration": {
"cadFile": {
"fileType": "string",
"filePath": "string",
"fileName": "string",
"fileObject": {}
},
"parts": {
"partId": "string",
"partName": "string",
"manufacturingDomain": "string",
"generalTolerance": "string",
"additionalRequirements": "string",
"material": {
"materialProperties": {
"value": "string",
"valueType": "string",
"propertyName": "string"
},
"materialFamily": "string"
},
"partQuantity": {
"quantityNumber": 0,
"measurementUnit": "string"
},
"billOfProcess": {
"process": [
{
"processStepIdentifier": [
"string"
],
"inputParameters": [
{
"name": "string",
"value": "string",
"semanticReference": [
"string"
],
"parameterKey": "HasValue",
"valueRangeList": [
{
"lowerValue": "string",
"upperValue": "string",
"name": "string"
}
],
"tolerances": [
{
"lowerLimit": "string",
"upperLimit": "string",
"name": "string"
}
]
}
],
"outputParameters": [
{
"name": "string",
"value": "string",
"semanticReference": [
"string"
],
"parameterKey": "HasValue",
"valueRangeList": [
{
"lowerValue": "string",
"upperValue": "string",
"name": "string"
}
],
"tolerances": [
{
"lowerLimit": "string",
"upperLimit": "string",
"name": "string"
}
]
}
],
"precedenceRelation": [
{
"precedenceElements": [
{
"successor": [
"string"
]
}
]
}
],
"childProcessSteps": [
"string"
],
"processStepType": "IsFirstElement",
"capabilityId": "string"
}
],
"productVersion": "string",
"productName": "string",
"billOfProcessIdentification": "string",
"version": "string"
}
},
"firstDeliveryDate": "2024-04-08",
"lastDeliveryDate": "2024-04-08",
"additionalComments": "string",
"additionalFiles": {
"fileType": "string",
"filePath": "string",
"fileName": "string",
"fileObject": {}
},
"orderQuantity": {
"quantityNumber": 0,
"measurementUnit": "string"
}
},
"rfqSender": {
"senderName": "string",
"senderAdress": "string",
"senderCompanyName": "string",
"senderEMail": "string",
"senderPhoneNumber": "string",
"senderAccountAddress": "string",
"senderDeliveryAddress": "string",
"deliveryRequirements": "string"
},
"cxHeader": {
"messageId": "string",
"context": "string",
"sentDateTime": "string",
"senderBpn": "string",
"receiverBpn": "string",
"expectedResponseBy": "string",
"relatedMessageId": "string",
"version": "string"
}
}
Payload or user input is invalid. See error details in the payload for more.
- application/json
- Schema
- Example (from schema)
Schema
error object
{
"error": {
"message": "string",
"path": "string",
"details": {},
"code": "string"
}
}
The requesting user or client is not authenticated.
The requesting user or client is not authorized to access resources for the given tenant.
The requested Twin has not been found.
POST /:api-endpoint/request-for-quotation
Request
Request
curl -L -X POST 'https://example.com/query-api/v3/:api-endpoint/request-for-quotation' \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
--data-raw '{
"filter": {
"description": "The request for quotation represents the data structure to configure a manufacturing request and send this to a supplier receive a quotation",
"type": "object",
"properties": {
"rfqIdentification": {
"description": "all properties necessary for identification of the request for quotation",
"type": "object",
"properties": {
"rfqSource": {
"description": "RFQ-Identification: digital address of the sender (e.g.token, IP address, link, user account)",
"type": "string"
},
"rfqId": {
"description": "RFQ-Identification: internal identifier in user account",
"type": "string"
},
"rfqName": {
"description": "RFQ-Identification: name for the request for user account management (usually name of the product to be manufactured)",
"type": "string"
},
"rfqDateTime": {
"description": "RFQ-Identification: date and time of the request in user account",
"type": "string",
"pattern": "-?([1-9][0-9]{3,}|0[0-9]{3})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T(([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9](.[0-9]+)?|(24:00:00(.0+)?))(Z|(+|-)((0[0-9]|1[0-3]):[0-5][0-9]|14:00))?"
},
"rfqVersion": {
"description": "RFQ-Identification: version of this request in case there were any changes",
"type": "string"
}
},
"required": [
"rfqId",
"rfqName",
"rfqDateTime",
"rfqVersion"
]
},
"rfqConfiguration": {
"description": "all information to configure a request for quotation",
"type": "object",
"properties": {
"cadFile": {
"description": "RFQ-Configuration: CAD file as geometry definition, e.g. step file",
"type": "object",
"properties": {
"fileType": {
"description": "RFQ-Configuration: file format",
"type": "string"
},
"filePath": {
"description": "path or address to the file ",
"type": "string"
},
"fileName": {
"description": "name of the file",
"type": "string"
},
"fileObject": {
"description": "the file object itself, in case this could be sent via the API",
"type": "object",
"properties": {}
}
},
"required": [
"fileType",
"fileName"
]
},
"parts": {
"description": "RFQ-Configuration: list of parts contained in the CAD file",
"type": "object",
"properties": {
"partId": {
"description": "RFQ-PartConfiguration: identifier of the part from CAD File",
"type": "string"
},
"partName": {
"description": "RFQ-PartConfiguration: name of the part in CAD file. In case the CAD file has only one part, this could also be the file name.",
"type": "string"
},
"manufacturingDomain": {
"description": "RFQ-PartConfiguration: domain of required process (e.g. subtractive manufacturing, additive manufacturing, assembly)",
"type": "string"
},
"generalTolerance": {
"description": "RFQ-PartConfiguration: selection of defined tolerance classes",
"type": "string"
},
"additionalRequirements": {
"description": "RFQ-PartConfiguration: specific requirements e.g. to guarantee quality, like premium quality check or standard quality check or test part required (makes only sense for batch)",
"type": "string"
},
"material": {
"description": "RFQ-PartConfiguration: material definition with further information",
"type": "object",
"properties": {
"materialProperties": {
"description": "material definition with additional detail properties with name, value and value type, like name= density, value=2.7, type=g/m3 or name= chemical term, value=AlMgMn, type=periodic table",
"type": "object",
"properties": {
"value": {
"description": "value to detail the part material item",
"type": "string"
},
"valueType": {
"description": "value type to specify the value of the property",
"type": "string"
},
"propertyName": {
"description": "name of the property",
"type": "string"
}
},
"required": [
"value",
"valueType",
"propertyName"
]
},
"materialFamily": {
"description": "definition of material family for preselection",
"type": "string"
}
},
"required": [
"materialProperties"
]
},
"partQuantity": {
"description": "RFQ-PartConfiguration: Quantity of which the part item is assembled into the parent item (within the CAD File). In general it is '\''1'\'' for serialized parts.",
"type": "object",
"properties": {
"quantityNumber": {
"description": "The number of objects related to the measurement unit",
"type": "number"
},
"measurementUnit": {
"description": "Unit of Measurement for the quantity of serialized objects",
"type": "string",
"pattern": "[a-zA-Z]*:[a-zA-Z]+"
}
},
"required": [
"quantityNumber",
"measurementUnit"
]
},
"billOfProcess": {
"description": "RFQ-PartConfiguration: list of process steps for part to be manufactured",
"type": "object",
"properties": {
"process": {
"description": "List that contains all manufacturing steps of a product, whereat each manufacturing step refers to exactly one capability. This list contains all process steps that are required to manufacture the product, specified with the bill of process ",
"type": "array",
"items": {
"description": "Entity to characterize single process steps",
"type": "object",
"properties": {
"processStepIdentifier": {
"description": "Unique identifier for a concrete process step",
"type": "array",
"items": {
"type": "string"
}
},
"inputParameters": {
"description": "Optional list of parameters that are required to execute the corresponding process step",
"type": "array",
"items": {
"description": "Generic entity to characterize parameters. It distinguished four cases: a parameter without a value, a parameter with a value, a parameter with a value range and a parameter with tolerances ",
"type": "object",
"properties": {
"name": {
"description": "Name of the parameter",
"type": "string"
},
"value": {
"description": "Value of the parameter",
"type": "string"
},
"semanticReference": {
"description": "Reference to a semantic namespace in which the type of the parameter is defined",
"type": "array",
"items": {
"type": "string"
}
},
"parameterKey": {
"description": "Enumeration that is used to distinguish whether the parameter has no value, has a value, has a value range or has a value with tolerances",
"type": "string",
"enum": [
"HasValue",
"HasNoValue",
"HasValueRange",
"HasTolerances"
]
},
"valueRangeList": {
"description": "List with value ranges for a parameter",
"type": "array",
"items": {
"description": "Entity for each value range item",
"type": "object",
"properties": {
"lowerValue": {
"description": "Lower border of a value range item",
"type": "string"
},
"upperValue": {
"description": "Upper border for a value range item",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerValue",
"upperValue"
]
}
},
"tolerances": {
"description": "Tolerances for a parameter ",
"type": "array",
"items": {
"description": "Entity to express the tolerances of a parameter",
"type": "object",
"properties": {
"lowerLimit": {
"description": "The lower direct limit of the tolerance",
"type": "string"
},
"upperLimit": {
"description": "Upper direct limit of the tolerance",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerLimit",
"upperLimit"
]
}
}
},
"required": [
"name",
"semanticReference",
"parameterKey"
]
}
},
"outputParameters": {
"description": "Optional list of parameters that are returned from the process step and can be used as inputParameters for subsequent steps",
"type": "array",
"items": {
"description": "Generic entity to characterize parameters. It distinguished four cases: a parameter without a value, a parameter with a value, a parameter with a value range and a parameter with tolerances ",
"type": "object",
"properties": {
"name": {
"description": "Name of the parameter",
"type": "string"
},
"value": {
"description": "Value of the parameter",
"type": "string"
},
"semanticReference": {
"description": "Reference to a semantic namespace in which the type of the parameter is defined",
"type": "array",
"items": {
"type": "string"
}
},
"parameterKey": {
"description": "Enumeration that is used to distinguish whether the parameter has no value, has a value, has a value range or has a value with tolerances",
"type": "string",
"enum": [
"HasValue",
"HasNoValue",
"HasValueRange",
"HasTolerances"
]
},
"valueRangeList": {
"description": "List with value ranges for a parameter",
"type": "array",
"items": {
"description": "Entity for each value range item",
"type": "object",
"properties": {
"lowerValue": {
"description": "Lower border of a value range item",
"type": "string"
},
"upperValue": {
"description": "Upper border for a value range item",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerValue",
"upperValue"
]
}
},
"tolerances": {
"description": "Tolerances for a parameter ",
"type": "array",
"items": {
"description": "Entity to express the tolerances of a parameter",
"type": "object",
"properties": {
"lowerLimit": {
"description": "The lower direct limit of the tolerance",
"type": "string"
},
"upperLimit": {
"description": "Upper direct limit of the tolerance",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerLimit",
"upperLimit"
]
}
}
},
"required": [
"name",
"semanticReference",
"parameterKey"
]
}
},
"precedenceRelation": {
"description": "List of alternative process steps from which the manufacturer has to select exactly one step to be executed. In case of no alternative process step, the list features only one element. In case of the last element, the property is not used, since the process step has no successor",
"type": "array",
"items": {
"description": "List of process steps that must be executed in parallel",
"type": "object",
"properties": {
"precedenceElements": {
"description": "List process steps that must be executed in parallel",
"type": "array",
"items": {
"description": "Entity to link the current process step to its successors",
"type": "object",
"properties": {
"successor": {
"description": "List of subsequent process step which can be executed in any order ",
"type": "array",
"items": {
"type": "string"
}
}
},
"required": [
"successor"
]
}
}
},
"required": [
"precedenceElements"
]
}
},
"childProcessSteps": {
"description": "List of child processes that need to be executed to complete the parent process step. It enables the expression of hierarchies between capabilities, e.g. a transport capability needs to execute at least a pick, a move and a place capability",
"type": "array",
"items": {
"type": "string"
}
},
"processStepType": {
"description": "Distinguishes process steps based on whether there are the first or last process step to be executed, or if they are a subprocess step, which subdivides a higher-level process step into smaller process steps",
"type": "string",
"enum": [
"IsFirstElement",
"IsLastElement",
"IsProcessElement",
"IsSubprocessElement"
]
},
"capabilityId": {
"description": "Locally unique identifier for a capability.",
"type": "string"
}
},
"required": [
"processStepIdentifier",
"processStepType",
"capabilityId"
]
}
},
"productVersion": {
"description": "Version of the product whose manufacturing steps are specified with the bill of process. It can for example specify a concrete variant of a product",
"type": "string"
},
"productName": {
"description": "Name of the product whose production steps are specified within the bill of process",
"type": "string"
},
"billOfProcessIdentification": {
"description": "Unique identifier for a bill of process that can be used to reference instances of the bill of process",
"type": "string"
},
"version": {
"description": "The unique identifier of the aspect model defining the structure and the semantics of the message'\''s header. The version number should reflect the versioning schema of aspect models in Catena-X.",
"type": "string",
"pattern": "^(0|[1-9][0-9]*).(0|[1-9][0-9]*).(0|[1-9][0-9]*)(-(0|[1-9A-Za-z-][0-9A-Za-z-]*)(.[0-9A-Za-z-]+)*)?([0-9A-Za-z-]+(.[0-9A-Za-z-]+)*)?$"
}
},
"required": [
"process",
"productVersion",
"productName",
"billOfProcessIdentification",
"version"
]
}
},
"required": [
"partId",
"partName",
"generalTolerance",
"material",
"partQuantity"
]
},
"firstDeliveryDate": {
"description": "RFQ-Configuration: Date of desired, first, but not must delivery",
"type": "string",
"format": "date"
},
"lastDeliveryDate": {
"description": "RFQ-Configuration: date of required and last acceptable delivery",
"type": "string",
"format": "date"
},
"additionalComments": {
"description": "RFQ-Configuration: placeholder for any kind of additional comments",
"type": "string"
},
"additionalFiles": {
"description": "RFQ-Configuration: in case there are additional documents or files to share (like e.g. technical drawings)",
"type": "object",
"properties": {
"fileType": {
"description": "RFQ-Configuration: file format",
"type": "string"
},
"filePath": {
"description": "path or address to the file ",
"type": "string"
},
"fileName": {
"description": "name of the file",
"type": "string"
},
"fileObject": {
"description": "the file object itself, in case this could be sent via the API",
"type": "object",
"properties": {}
}
},
"required": [
"fileType",
"fileName"
]
},
"orderQuantity": {
"description": "RFQ-Configuration: quantity at all, valid for complete order (usually number of products to be ordered)",
"type": "object",
"properties": {
"quantityNumber": {
"description": "The number of objects related to the measurement unit",
"type": "number"
},
"measurementUnit": {
"description": "Unit of Measurement for the quantity of serialized objects",
"type": "string",
"pattern": "[a-zA-Z]*:[a-zA-Z]+"
}
},
"required": [
"quantityNumber",
"measurementUnit"
]
}
},
"required": [
"cadFile",
"parts",
"lastDeliveryDate",
"orderQuantity"
]
},
"rfqSender": {
"description": "all data about sender of request for quotation, important for offer and delivery",
"type": "object",
"properties": {
"senderName": {
"description": "RFQ-Sender: name of the sender",
"type": "string"
},
"senderAdress": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, address of sender",
"type": "string"
},
"senderCompanyName": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, company name of sender",
"type": "string"
},
"senderEMail": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, e-mail address of sender",
"type": "string"
},
"senderPhoneNumber": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, phone number of sender",
"type": "string"
},
"senderAccountAddress": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, address of sender for account",
"type": "string"
},
"senderDeliveryAddress": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, address of sender for delivery",
"type": "string"
},
"deliveryRequirements": {
"description": "RFQ-Sender: filled by customer, any kind of delivery requirements",
"type": "string"
}
},
"required": [
"senderName",
"senderAdress",
"senderEMail",
"senderPhoneNumber",
"senderAccountAddress",
"senderDeliveryAddress"
]
},
"cxHeader": {
"description": "header information by Catena-X",
"type": "object",
"properties": {
"messageId": {
"description": "Unique ID identifying the message. The purpose of the ID is to uniquely identify a single message, therefore it MUST not be reused.",
"type": "string",
"pattern": "(^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)|(^urn:uuid:[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)"
},
"context": {
"description": "Information about the context the message should be considered in.\nThe value MUST consist of two parts: an identifier of the context (e.g. business domain, etc.) followed by a version number.\nBoth the identifier and the version number MUST correspond to the content of the message.\nIf the content of a message is described by an aspect model available in the Catena-X Semantic Hub, then the unique identifier of this semantic model (e.g. urn:samm:io.catenax.<ASPECT-MODEL-NAME>:1.x.x) MUST be used as a value of the context field. This is considered the default case.\nIn all other cases the value of the context field MUST follow the pattern <domain>-<subdomain>-<object>:<[major] version> (e.g. TRACE-QM-Alert:1.x.x).\nVersioning only refers to major versions in both default and fallback cases.\nNote: The version of the message'\''s header is specified in the version field.",
"type": "string"
},
"sentDateTime": {
"description": "Time zone aware timestamp holding the date and the time the message was sent by the sending party. The value MUST be formatted according to the ISO 8601 standard",
"type": "string",
"pattern": "-?([1-9][0-9]{3,}|0[0-9]{3})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T(([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9](.[0-9]+)?|(24:00:00(.0+)?))(Z|(+|-)((0[0-9]|1[0-3]):[0-5][0-9]|14:00))?"
},
"senderBpn": {
"description": "The Business Partner Number of the sending party. The value MUST be a valid BPN. BPNA and BPNS are not allowed. Applicable constraints are defined in the corresponding standard",
"type": "string",
"pattern": "^BPNL[a-zA-Z0-9]{12}$"
},
"receiverBpn": {
"description": "The Business Partner Number of the receiving party. The value MUST be a valid BPN. BPNA and BPNS are not allowed. Applicable constraints are defined in the corresponding standard.",
"type": "string",
"pattern": "^BPNL[a-zA-Z0-9]{12}$"
},
"expectedResponseBy": {
"description": "Time zone aware timestamp holding the date and time by which the sending party expects a certain type of response from the receiving party. The meaning and interpretation of the fields'\''s value are context-bound and MUST therefore be defined by any business domain or platform capability making use of it. The value MUST be formatted according to the ISO 8601 standard",
"type": "string",
"pattern": "-?([1-9][0-9]{3,}|0[0-9]{3})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T(([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9](.[0-9]+)?|(24:00:00(.0+)?))(Z|(+|-)((0[0-9]|1[0-3]):[0-5][0-9]|14:00))?"
},
"relatedMessageId": {
"description": "Unique ID identifying a message somehow related to the current one",
"type": "string",
"pattern": "(^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)|(^urn:uuid:[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)"
},
"version": {
"description": "The unique identifier of the aspect model defining the structure and the semantics of the message'\''s header. The version number should reflect the versioning schema of aspect models in Catena-X.",
"type": "string",
"pattern": "^(0|[1-9][0-9]*).(0|[1-9][0-9]*).(0|[1-9][0-9]*)(-(0|[1-9A-Za-z-][0-9A-Za-z-]*)(.[0-9A-Za-z-]+)*)?([0-9A-Za-z-]+(.[0-9A-Za-z-]+)*)?$"
}
},
"required": [
"messageId",
"context",
"sentDateTime",
"senderBpn",
"receiverBpn",
"version"
]
}
},
"required": [
"rfqIdentification",
"rfqConfiguration",
"rfqSender",
"cxHeader"
]
}
}'
curl -L -X POST 'https://example.com/query-api/v3/:api-endpoint/request-for-quotation' \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
--data-raw '{
"filter": {
"description": "The request for quotation represents the data structure to configure a manufacturing request and send this to a supplier receive a quotation",
"type": "object",
"properties": {
"rfqIdentification": {
"description": "all properties necessary for identification of the request for quotation",
"type": "object",
"properties": {
"rfqSource": {
"description": "RFQ-Identification: digital address of the sender (e.g.token, IP address, link, user account)",
"type": "string"
},
"rfqId": {
"description": "RFQ-Identification: internal identifier in user account",
"type": "string"
},
"rfqName": {
"description": "RFQ-Identification: name for the request for user account management (usually name of the product to be manufactured)",
"type": "string"
},
"rfqDateTime": {
"description": "RFQ-Identification: date and time of the request in user account",
"type": "string",
"pattern": "-?([1-9][0-9]{3,}|0[0-9]{3})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T(([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9](.[0-9]+)?|(24:00:00(.0+)?))(Z|(+|-)((0[0-9]|1[0-3]):[0-5][0-9]|14:00))?"
},
"rfqVersion": {
"description": "RFQ-Identification: version of this request in case there were any changes",
"type": "string"
}
},
"required": [
"rfqId",
"rfqName",
"rfqDateTime",
"rfqVersion"
]
},
"rfqConfiguration": {
"description": "all information to configure a request for quotation",
"type": "object",
"properties": {
"cadFile": {
"description": "RFQ-Configuration: CAD file as geometry definition, e.g. step file",
"type": "object",
"properties": {
"fileType": {
"description": "RFQ-Configuration: file format",
"type": "string"
},
"filePath": {
"description": "path or address to the file ",
"type": "string"
},
"fileName": {
"description": "name of the file",
"type": "string"
},
"fileObject": {
"description": "the file object itself, in case this could be sent via the API",
"type": "object",
"properties": {}
}
},
"required": [
"fileType",
"fileName"
]
},
"parts": {
"description": "RFQ-Configuration: list of parts contained in the CAD file",
"type": "object",
"properties": {
"partId": {
"description": "RFQ-PartConfiguration: identifier of the part from CAD File",
"type": "string"
},
"partName": {
"description": "RFQ-PartConfiguration: name of the part in CAD file. In case the CAD file has only one part, this could also be the file name.",
"type": "string"
},
"manufacturingDomain": {
"description": "RFQ-PartConfiguration: domain of required process (e.g. subtractive manufacturing, additive manufacturing, assembly)",
"type": "string"
},
"generalTolerance": {
"description": "RFQ-PartConfiguration: selection of defined tolerance classes",
"type": "string"
},
"additionalRequirements": {
"description": "RFQ-PartConfiguration: specific requirements e.g. to guarantee quality, like premium quality check or standard quality check or test part required (makes only sense for batch)",
"type": "string"
},
"material": {
"description": "RFQ-PartConfiguration: material definition with further information",
"type": "object",
"properties": {
"materialProperties": {
"description": "material definition with additional detail properties with name, value and value type, like name= density, value=2.7, type=g/m3 or name= chemical term, value=AlMgMn, type=periodic table",
"type": "object",
"properties": {
"value": {
"description": "value to detail the part material item",
"type": "string"
},
"valueType": {
"description": "value type to specify the value of the property",
"type": "string"
},
"propertyName": {
"description": "name of the property",
"type": "string"
}
},
"required": [
"value",
"valueType",
"propertyName"
]
},
"materialFamily": {
"description": "definition of material family for preselection",
"type": "string"
}
},
"required": [
"materialProperties"
]
},
"partQuantity": {
"description": "RFQ-PartConfiguration: Quantity of which the part item is assembled into the parent item (within the CAD File). In general it is '\''1'\'' for serialized parts.",
"type": "object",
"properties": {
"quantityNumber": {
"description": "The number of objects related to the measurement unit",
"type": "number"
},
"measurementUnit": {
"description": "Unit of Measurement for the quantity of serialized objects",
"type": "string",
"pattern": "[a-zA-Z]*:[a-zA-Z]+"
}
},
"required": [
"quantityNumber",
"measurementUnit"
]
},
"billOfProcess": {
"description": "RFQ-PartConfiguration: list of process steps for part to be manufactured",
"type": "object",
"properties": {
"process": {
"description": "List that contains all manufacturing steps of a product, whereat each manufacturing step refers to exactly one capability. This list contains all process steps that are required to manufacture the product, specified with the bill of process ",
"type": "array",
"items": {
"description": "Entity to characterize single process steps",
"type": "object",
"properties": {
"processStepIdentifier": {
"description": "Unique identifier for a concrete process step",
"type": "array",
"items": {
"type": "string"
}
},
"inputParameters": {
"description": "Optional list of parameters that are required to execute the corresponding process step",
"type": "array",
"items": {
"description": "Generic entity to characterize parameters. It distinguished four cases: a parameter without a value, a parameter with a value, a parameter with a value range and a parameter with tolerances ",
"type": "object",
"properties": {
"name": {
"description": "Name of the parameter",
"type": "string"
},
"value": {
"description": "Value of the parameter",
"type": "string"
},
"semanticReference": {
"description": "Reference to a semantic namespace in which the type of the parameter is defined",
"type": "array",
"items": {
"type": "string"
}
},
"parameterKey": {
"description": "Enumeration that is used to distinguish whether the parameter has no value, has a value, has a value range or has a value with tolerances",
"type": "string",
"enum": [
"HasValue",
"HasNoValue",
"HasValueRange",
"HasTolerances"
]
},
"valueRangeList": {
"description": "List with value ranges for a parameter",
"type": "array",
"items": {
"description": "Entity for each value range item",
"type": "object",
"properties": {
"lowerValue": {
"description": "Lower border of a value range item",
"type": "string"
},
"upperValue": {
"description": "Upper border for a value range item",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerValue",
"upperValue"
]
}
},
"tolerances": {
"description": "Tolerances for a parameter ",
"type": "array",
"items": {
"description": "Entity to express the tolerances of a parameter",
"type": "object",
"properties": {
"lowerLimit": {
"description": "The lower direct limit of the tolerance",
"type": "string"
},
"upperLimit": {
"description": "Upper direct limit of the tolerance",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerLimit",
"upperLimit"
]
}
}
},
"required": [
"name",
"semanticReference",
"parameterKey"
]
}
},
"outputParameters": {
"description": "Optional list of parameters that are returned from the process step and can be used as inputParameters for subsequent steps",
"type": "array",
"items": {
"description": "Generic entity to characterize parameters. It distinguished four cases: a parameter without a value, a parameter with a value, a parameter with a value range and a parameter with tolerances ",
"type": "object",
"properties": {
"name": {
"description": "Name of the parameter",
"type": "string"
},
"value": {
"description": "Value of the parameter",
"type": "string"
},
"semanticReference": {
"description": "Reference to a semantic namespace in which the type of the parameter is defined",
"type": "array",
"items": {
"type": "string"
}
},
"parameterKey": {
"description": "Enumeration that is used to distinguish whether the parameter has no value, has a value, has a value range or has a value with tolerances",
"type": "string",
"enum": [
"HasValue",
"HasNoValue",
"HasValueRange",
"HasTolerances"
]
},
"valueRangeList": {
"description": "List with value ranges for a parameter",
"type": "array",
"items": {
"description": "Entity for each value range item",
"type": "object",
"properties": {
"lowerValue": {
"description": "Lower border of a value range item",
"type": "string"
},
"upperValue": {
"description": "Upper border for a value range item",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerValue",
"upperValue"
]
}
},
"tolerances": {
"description": "Tolerances for a parameter ",
"type": "array",
"items": {
"description": "Entity to express the tolerances of a parameter",
"type": "object",
"properties": {
"lowerLimit": {
"description": "The lower direct limit of the tolerance",
"type": "string"
},
"upperLimit": {
"description": "Upper direct limit of the tolerance",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerLimit",
"upperLimit"
]
}
}
},
"required": [
"name",
"semanticReference",
"parameterKey"
]
}
},
"precedenceRelation": {
"description": "List of alternative process steps from which the manufacturer has to select exactly one step to be executed. In case of no alternative process step, the list features only one element. In case of the last element, the property is not used, since the process step has no successor",
"type": "array",
"items": {
"description": "List of process steps that must be executed in parallel",
"type": "object",
"properties": {
"precedenceElements": {
"description": "List process steps that must be executed in parallel",
"type": "array",
"items": {
"description": "Entity to link the current process step to its successors",
"type": "object",
"properties": {
"successor": {
"description": "List of subsequent process step which can be executed in any order ",
"type": "array",
"items": {
"type": "string"
}
}
},
"required": [
"successor"
]
}
}
},
"required": [
"precedenceElements"
]
}
},
"childProcessSteps": {
"description": "List of child processes that need to be executed to complete the parent process step. It enables the expression of hierarchies between capabilities, e.g. a transport capability needs to execute at least a pick, a move and a place capability",
"type": "array",
"items": {
"type": "string"
}
},
"processStepType": {
"description": "Distinguishes process steps based on whether there are the first or last process step to be executed, or if they are a subprocess step, which subdivides a higher-level process step into smaller process steps",
"type": "string",
"enum": [
"IsFirstElement",
"IsLastElement",
"IsProcessElement",
"IsSubprocessElement"
]
},
"capabilityId": {
"description": "Locally unique identifier for a capability.",
"type": "string"
}
},
"required": [
"processStepIdentifier",
"processStepType",
"capabilityId"
]
}
},
"productVersion": {
"description": "Version of the product whose manufacturing steps are specified with the bill of process. It can for example specify a concrete variant of a product",
"type": "string"
},
"productName": {
"description": "Name of the product whose production steps are specified within the bill of process",
"type": "string"
},
"billOfProcessIdentification": {
"description": "Unique identifier for a bill of process that can be used to reference instances of the bill of process",
"type": "string"
},
"version": {
"description": "The unique identifier of the aspect model defining the structure and the semantics of the message'\''s header. The version number should reflect the versioning schema of aspect models in Catena-X.",
"type": "string",
"pattern": "^(0|[1-9][0-9]*).(0|[1-9][0-9]*).(0|[1-9][0-9]*)(-(0|[1-9A-Za-z-][0-9A-Za-z-]*)(.[0-9A-Za-z-]+)*)?([0-9A-Za-z-]+(.[0-9A-Za-z-]+)*)?$"
}
},
"required": [
"process",
"productVersion",
"productName",
"billOfProcessIdentification",
"version"
]
}
},
"required": [
"partId",
"partName",
"generalTolerance",
"material",
"partQuantity"
]
},
"firstDeliveryDate": {
"description": "RFQ-Configuration: Date of desired, first, but not must delivery",
"type": "string",
"format": "date"
},
"lastDeliveryDate": {
"description": "RFQ-Configuration: date of required and last acceptable delivery",
"type": "string",
"format": "date"
},
"additionalComments": {
"description": "RFQ-Configuration: placeholder for any kind of additional comments",
"type": "string"
},
"additionalFiles": {
"description": "RFQ-Configuration: in case there are additional documents or files to share (like e.g. technical drawings)",
"type": "object",
"properties": {
"fileType": {
"description": "RFQ-Configuration: file format",
"type": "string"
},
"filePath": {
"description": "path or address to the file ",
"type": "string"
},
"fileName": {
"description": "name of the file",
"type": "string"
},
"fileObject": {
"description": "the file object itself, in case this could be sent via the API",
"type": "object",
"properties": {}
}
},
"required": [
"fileType",
"fileName"
]
},
"orderQuantity": {
"description": "RFQ-Configuration: quantity at all, valid for complete order (usually number of products to be ordered)",
"type": "object",
"properties": {
"quantityNumber": {
"description": "The number of objects related to the measurement unit",
"type": "number"
},
"measurementUnit": {
"description": "Unit of Measurement for the quantity of serialized objects",
"type": "string",
"pattern": "[a-zA-Z]*:[a-zA-Z]+"
}
},
"required": [
"quantityNumber",
"measurementUnit"
]
}
},
"required": [
"cadFile",
"parts",
"lastDeliveryDate",
"orderQuantity"
]
},
"rfqSender": {
"description": "all data about sender of request for quotation, important for offer and delivery",
"type": "object",
"properties": {
"senderName": {
"description": "RFQ-Sender: name of the sender",
"type": "string"
},
"senderAdress": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, address of sender",
"type": "string"
},
"senderCompanyName": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, company name of sender",
"type": "string"
},
"senderEMail": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, e-mail address of sender",
"type": "string"
},
"senderPhoneNumber": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, phone number of sender",
"type": "string"
},
"senderAccountAddress": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, address of sender for account",
"type": "string"
},
"senderDeliveryAddress": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, address of sender for delivery",
"type": "string"
},
"deliveryRequirements": {
"description": "RFQ-Sender: filled by customer, any kind of delivery requirements",
"type": "string"
}
},
"required": [
"senderName",
"senderAdress",
"senderEMail",
"senderPhoneNumber",
"senderAccountAddress",
"senderDeliveryAddress"
]
},
"cxHeader": {
"description": "header information by Catena-X",
"type": "object",
"properties": {
"messageId": {
"description": "Unique ID identifying the message. The purpose of the ID is to uniquely identify a single message, therefore it MUST not be reused.",
"type": "string",
"pattern": "(^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)|(^urn:uuid:[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)"
},
"context": {
"description": "Information about the context the message should be considered in.\nThe value MUST consist of two parts: an identifier of the context (e.g. business domain, etc.) followed by a version number.\nBoth the identifier and the version number MUST correspond to the content of the message.\nIf the content of a message is described by an aspect model available in the Catena-X Semantic Hub, then the unique identifier of this semantic model (e.g. urn:samm:io.catenax.<ASPECT-MODEL-NAME>:1.x.x) MUST be used as a value of the context field. This is considered the default case.\nIn all other cases the value of the context field MUST follow the pattern <domain>-<subdomain>-<object>:<[major] version> (e.g. TRACE-QM-Alert:1.x.x).\nVersioning only refers to major versions in both default and fallback cases.\nNote: The version of the message'\''s header is specified in the version field.",
"type": "string"
},
"sentDateTime": {
"description": "Time zone aware timestamp holding the date and the time the message was sent by the sending party. The value MUST be formatted according to the ISO 8601 standard",
"type": "string",
"pattern": "-?([1-9][0-9]{3,}|0[0-9]{3})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T(([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9](.[0-9]+)?|(24:00:00(.0+)?))(Z|(+|-)((0[0-9]|1[0-3]):[0-5][0-9]|14:00))?"
},
"senderBpn": {
"description": "The Business Partner Number of the sending party. The value MUST be a valid BPN. BPNA and BPNS are not allowed. Applicable constraints are defined in the corresponding standard",
"type": "string",
"pattern": "^BPNL[a-zA-Z0-9]{12}$"
},
"receiverBpn": {
"description": "The Business Partner Number of the receiving party. The value MUST be a valid BPN. BPNA and BPNS are not allowed. Applicable constraints are defined in the corresponding standard.",
"type": "string",
"pattern": "^BPNL[a-zA-Z0-9]{12}$"
},
"expectedResponseBy": {
"description": "Time zone aware timestamp holding the date and time by which the sending party expects a certain type of response from the receiving party. The meaning and interpretation of the fields'\''s value are context-bound and MUST therefore be defined by any business domain or platform capability making use of it. The value MUST be formatted according to the ISO 8601 standard",
"type": "string",
"pattern": "-?([1-9][0-9]{3,}|0[0-9]{3})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T(([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9](.[0-9]+)?|(24:00:00(.0+)?))(Z|(+|-)((0[0-9]|1[0-3]):[0-5][0-9]|14:00))?"
},
"relatedMessageId": {
"description": "Unique ID identifying a message somehow related to the current one",
"type": "string",
"pattern": "(^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)|(^urn:uuid:[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)"
},
"version": {
"description": "The unique identifier of the aspect model defining the structure and the semantics of the message'\''s header. The version number should reflect the versioning schema of aspect models in Catena-X.",
"type": "string",
"pattern": "^(0|[1-9][0-9]*).(0|[1-9][0-9]*).(0|[1-9][0-9]*)(-(0|[1-9A-Za-z-][0-9A-Za-z-]*)(.[0-9A-Za-z-]+)*)?([0-9A-Za-z-]+(.[0-9A-Za-z-]+)*)?$"
}
},
"required": [
"messageId",
"context",
"sentDateTime",
"senderBpn",
"receiverBpn",
"version"
]
}
},
"required": [
"rfqIdentification",
"rfqConfiguration",
"rfqSender",
"cxHeader"
]
}
}'
curl -L -X POST 'https://example.com/query-api/v3/:api-endpoint/request-for-quotation' \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
--data-raw '{
"filter": {
"description": "The request for quotation represents the data structure to configure a manufacturing request and send this to a supplier receive a quotation",
"type": "object",
"properties": {
"rfqIdentification": {
"description": "all properties necessary for identification of the request for quotation",
"type": "object",
"properties": {
"rfqSource": {
"description": "RFQ-Identification: digital address of the sender (e.g.token, IP address, link, user account)",
"type": "string"
},
"rfqId": {
"description": "RFQ-Identification: internal identifier in user account",
"type": "string"
},
"rfqName": {
"description": "RFQ-Identification: name for the request for user account management (usually name of the product to be manufactured)",
"type": "string"
},
"rfqDateTime": {
"description": "RFQ-Identification: date and time of the request in user account",
"type": "string",
"pattern": "-?([1-9][0-9]{3,}|0[0-9]{3})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T(([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9](.[0-9]+)?|(24:00:00(.0+)?))(Z|(+|-)((0[0-9]|1[0-3]):[0-5][0-9]|14:00))?"
},
"rfqVersion": {
"description": "RFQ-Identification: version of this request in case there were any changes",
"type": "string"
}
},
"required": [
"rfqId",
"rfqName",
"rfqDateTime",
"rfqVersion"
]
},
"rfqConfiguration": {
"description": "all information to configure a request for quotation",
"type": "object",
"properties": {
"cadFile": {
"description": "RFQ-Configuration: CAD file as geometry definition, e.g. step file",
"type": "object",
"properties": {
"fileType": {
"description": "RFQ-Configuration: file format",
"type": "string"
},
"filePath": {
"description": "path or address to the file ",
"type": "string"
},
"fileName": {
"description": "name of the file",
"type": "string"
},
"fileObject": {
"description": "the file object itself, in case this could be sent via the API",
"type": "object",
"properties": {}
}
},
"required": [
"fileType",
"fileName"
]
},
"parts": {
"description": "RFQ-Configuration: list of parts contained in the CAD file",
"type": "object",
"properties": {
"partId": {
"description": "RFQ-PartConfiguration: identifier of the part from CAD File",
"type": "string"
},
"partName": {
"description": "RFQ-PartConfiguration: name of the part in CAD file. In case the CAD file has only one part, this could also be the file name.",
"type": "string"
},
"manufacturingDomain": {
"description": "RFQ-PartConfiguration: domain of required process (e.g. subtractive manufacturing, additive manufacturing, assembly)",
"type": "string"
},
"generalTolerance": {
"description": "RFQ-PartConfiguration: selection of defined tolerance classes",
"type": "string"
},
"additionalRequirements": {
"description": "RFQ-PartConfiguration: specific requirements e.g. to guarantee quality, like premium quality check or standard quality check or test part required (makes only sense for batch)",
"type": "string"
},
"material": {
"description": "RFQ-PartConfiguration: material definition with further information",
"type": "object",
"properties": {
"materialProperties": {
"description": "material definition with additional detail properties with name, value and value type, like name= density, value=2.7, type=g/m3 or name= chemical term, value=AlMgMn, type=periodic table",
"type": "object",
"properties": {
"value": {
"description": "value to detail the part material item",
"type": "string"
},
"valueType": {
"description": "value type to specify the value of the property",
"type": "string"
},
"propertyName": {
"description": "name of the property",
"type": "string"
}
},
"required": [
"value",
"valueType",
"propertyName"
]
},
"materialFamily": {
"description": "definition of material family for preselection",
"type": "string"
}
},
"required": [
"materialProperties"
]
},
"partQuantity": {
"description": "RFQ-PartConfiguration: Quantity of which the part item is assembled into the parent item (within the CAD File). In general it is '\''1'\'' for serialized parts.",
"type": "object",
"properties": {
"quantityNumber": {
"description": "The number of objects related to the measurement unit",
"type": "number"
},
"measurementUnit": {
"description": "Unit of Measurement for the quantity of serialized objects",
"type": "string",
"pattern": "[a-zA-Z]*:[a-zA-Z]+"
}
},
"required": [
"quantityNumber",
"measurementUnit"
]
},
"billOfProcess": {
"description": "RFQ-PartConfiguration: list of process steps for part to be manufactured",
"type": "object",
"properties": {
"process": {
"description": "List that contains all manufacturing steps of a product, whereat each manufacturing step refers to exactly one capability. This list contains all process steps that are required to manufacture the product, specified with the bill of process ",
"type": "array",
"items": {
"description": "Entity to characterize single process steps",
"type": "object",
"properties": {
"processStepIdentifier": {
"description": "Unique identifier for a concrete process step",
"type": "array",
"items": {
"type": "string"
}
},
"inputParameters": {
"description": "Optional list of parameters that are required to execute the corresponding process step",
"type": "array",
"items": {
"description": "Generic entity to characterize parameters. It distinguished four cases: a parameter without a value, a parameter with a value, a parameter with a value range and a parameter with tolerances ",
"type": "object",
"properties": {
"name": {
"description": "Name of the parameter",
"type": "string"
},
"value": {
"description": "Value of the parameter",
"type": "string"
},
"semanticReference": {
"description": "Reference to a semantic namespace in which the type of the parameter is defined",
"type": "array",
"items": {
"type": "string"
}
},
"parameterKey": {
"description": "Enumeration that is used to distinguish whether the parameter has no value, has a value, has a value range or has a value with tolerances",
"type": "string",
"enum": [
"HasValue",
"HasNoValue",
"HasValueRange",
"HasTolerances"
]
},
"valueRangeList": {
"description": "List with value ranges for a parameter",
"type": "array",
"items": {
"description": "Entity for each value range item",
"type": "object",
"properties": {
"lowerValue": {
"description": "Lower border of a value range item",
"type": "string"
},
"upperValue": {
"description": "Upper border for a value range item",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerValue",
"upperValue"
]
}
},
"tolerances": {
"description": "Tolerances for a parameter ",
"type": "array",
"items": {
"description": "Entity to express the tolerances of a parameter",
"type": "object",
"properties": {
"lowerLimit": {
"description": "The lower direct limit of the tolerance",
"type": "string"
},
"upperLimit": {
"description": "Upper direct limit of the tolerance",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerLimit",
"upperLimit"
]
}
}
},
"required": [
"name",
"semanticReference",
"parameterKey"
]
}
},
"outputParameters": {
"description": "Optional list of parameters that are returned from the process step and can be used as inputParameters for subsequent steps",
"type": "array",
"items": {
"description": "Generic entity to characterize parameters. It distinguished four cases: a parameter without a value, a parameter with a value, a parameter with a value range and a parameter with tolerances ",
"type": "object",
"properties": {
"name": {
"description": "Name of the parameter",
"type": "string"
},
"value": {
"description": "Value of the parameter",
"type": "string"
},
"semanticReference": {
"description": "Reference to a semantic namespace in which the type of the parameter is defined",
"type": "array",
"items": {
"type": "string"
}
},
"parameterKey": {
"description": "Enumeration that is used to distinguish whether the parameter has no value, has a value, has a value range or has a value with tolerances",
"type": "string",
"enum": [
"HasValue",
"HasNoValue",
"HasValueRange",
"HasTolerances"
]
},
"valueRangeList": {
"description": "List with value ranges for a parameter",
"type": "array",
"items": {
"description": "Entity for each value range item",
"type": "object",
"properties": {
"lowerValue": {
"description": "Lower border of a value range item",
"type": "string"
},
"upperValue": {
"description": "Upper border for a value range item",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerValue",
"upperValue"
]
}
},
"tolerances": {
"description": "Tolerances for a parameter ",
"type": "array",
"items": {
"description": "Entity to express the tolerances of a parameter",
"type": "object",
"properties": {
"lowerLimit": {
"description": "The lower direct limit of the tolerance",
"type": "string"
},
"upperLimit": {
"description": "Upper direct limit of the tolerance",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerLimit",
"upperLimit"
]
}
}
},
"required": [
"name",
"semanticReference",
"parameterKey"
]
}
},
"precedenceRelation": {
"description": "List of alternative process steps from which the manufacturer has to select exactly one step to be executed. In case of no alternative process step, the list features only one element. In case of the last element, the property is not used, since the process step has no successor",
"type": "array",
"items": {
"description": "List of process steps that must be executed in parallel",
"type": "object",
"properties": {
"precedenceElements": {
"description": "List process steps that must be executed in parallel",
"type": "array",
"items": {
"description": "Entity to link the current process step to its successors",
"type": "object",
"properties": {
"successor": {
"description": "List of subsequent process step which can be executed in any order ",
"type": "array",
"items": {
"type": "string"
}
}
},
"required": [
"successor"
]
}
}
},
"required": [
"precedenceElements"
]
}
},
"childProcessSteps": {
"description": "List of child processes that need to be executed to complete the parent process step. It enables the expression of hierarchies between capabilities, e.g. a transport capability needs to execute at least a pick, a move and a place capability",
"type": "array",
"items": {
"type": "string"
}
},
"processStepType": {
"description": "Distinguishes process steps based on whether there are the first or last process step to be executed, or if they are a subprocess step, which subdivides a higher-level process step into smaller process steps",
"type": "string",
"enum": [
"IsFirstElement",
"IsLastElement",
"IsProcessElement",
"IsSubprocessElement"
]
},
"capabilityId": {
"description": "Locally unique identifier for a capability.",
"type": "string"
}
},
"required": [
"processStepIdentifier",
"processStepType",
"capabilityId"
]
}
},
"productVersion": {
"description": "Version of the product whose manufacturing steps are specified with the bill of process. It can for example specify a concrete variant of a product",
"type": "string"
},
"productName": {
"description": "Name of the product whose production steps are specified within the bill of process",
"type": "string"
},
"billOfProcessIdentification": {
"description": "Unique identifier for a bill of process that can be used to reference instances of the bill of process",
"type": "string"
},
"version": {
"description": "The unique identifier of the aspect model defining the structure and the semantics of the message'\''s header. The version number should reflect the versioning schema of aspect models in Catena-X.",
"type": "string",
"pattern": "^(0|[1-9][0-9]*).(0|[1-9][0-9]*).(0|[1-9][0-9]*)(-(0|[1-9A-Za-z-][0-9A-Za-z-]*)(.[0-9A-Za-z-]+)*)?([0-9A-Za-z-]+(.[0-9A-Za-z-]+)*)?$"
}
},
"required": [
"process",
"productVersion",
"productName",
"billOfProcessIdentification",
"version"
]
}
},
"required": [
"partId",
"partName",
"generalTolerance",
"material",
"partQuantity"
]
},
"firstDeliveryDate": {
"description": "RFQ-Configuration: Date of desired, first, but not must delivery",
"type": "string",
"format": "date"
},
"lastDeliveryDate": {
"description": "RFQ-Configuration: date of required and last acceptable delivery",
"type": "string",
"format": "date"
},
"additionalComments": {
"description": "RFQ-Configuration: placeholder for any kind of additional comments",
"type": "string"
},
"additionalFiles": {
"description": "RFQ-Configuration: in case there are additional documents or files to share (like e.g. technical drawings)",
"type": "object",
"properties": {
"fileType": {
"description": "RFQ-Configuration: file format",
"type": "string"
},
"filePath": {
"description": "path or address to the file ",
"type": "string"
},
"fileName": {
"description": "name of the file",
"type": "string"
},
"fileObject": {
"description": "the file object itself, in case this could be sent via the API",
"type": "object",
"properties": {}
}
},
"required": [
"fileType",
"fileName"
]
},
"orderQuantity": {
"description": "RFQ-Configuration: quantity at all, valid for complete order (usually number of products to be ordered)",
"type": "object",
"properties": {
"quantityNumber": {
"description": "The number of objects related to the measurement unit",
"type": "number"
},
"measurementUnit": {
"description": "Unit of Measurement for the quantity of serialized objects",
"type": "string",
"pattern": "[a-zA-Z]*:[a-zA-Z]+"
}
},
"required": [
"quantityNumber",
"measurementUnit"
]
}
},
"required": [
"cadFile",
"parts",
"lastDeliveryDate",
"orderQuantity"
]
},
"rfqSender": {
"description": "all data about sender of request for quotation, important for offer and delivery",
"type": "object",
"properties": {
"senderName": {
"description": "RFQ-Sender: name of the sender",
"type": "string"
},
"senderAdress": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, address of sender",
"type": "string"
},
"senderCompanyName": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, company name of sender",
"type": "string"
},
"senderEMail": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, e-mail address of sender",
"type": "string"
},
"senderPhoneNumber": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, phone number of sender",
"type": "string"
},
"senderAccountAddress": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, address of sender for account",
"type": "string"
},
"senderDeliveryAddress": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, address of sender for delivery",
"type": "string"
},
"deliveryRequirements": {
"description": "RFQ-Sender: filled by customer, any kind of delivery requirements",
"type": "string"
}
},
"required": [
"senderName",
"senderAdress",
"senderEMail",
"senderPhoneNumber",
"senderAccountAddress",
"senderDeliveryAddress"
]
},
"cxHeader": {
"description": "header information by Catena-X",
"type": "object",
"properties": {
"messageId": {
"description": "Unique ID identifying the message. The purpose of the ID is to uniquely identify a single message, therefore it MUST not be reused.",
"type": "string",
"pattern": "(^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)|(^urn:uuid:[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)"
},
"context": {
"description": "Information about the context the message should be considered in.\nThe value MUST consist of two parts: an identifier of the context (e.g. business domain, etc.) followed by a version number.\nBoth the identifier and the version number MUST correspond to the content of the message.\nIf the content of a message is described by an aspect model available in the Catena-X Semantic Hub, then the unique identifier of this semantic model (e.g. urn:samm:io.catenax.<ASPECT-MODEL-NAME>:1.x.x) MUST be used as a value of the context field. This is considered the default case.\nIn all other cases the value of the context field MUST follow the pattern <domain>-<subdomain>-<object>:<[major] version> (e.g. TRACE-QM-Alert:1.x.x).\nVersioning only refers to major versions in both default and fallback cases.\nNote: The version of the message'\''s header is specified in the version field.",
"type": "string"
},
"sentDateTime": {
"description": "Time zone aware timestamp holding the date and the time the message was sent by the sending party. The value MUST be formatted according to the ISO 8601 standard",
"type": "string",
"pattern": "-?([1-9][0-9]{3,}|0[0-9]{3})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T(([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9](.[0-9]+)?|(24:00:00(.0+)?))(Z|(+|-)((0[0-9]|1[0-3]):[0-5][0-9]|14:00))?"
},
"senderBpn": {
"description": "The Business Partner Number of the sending party. The value MUST be a valid BPN. BPNA and BPNS are not allowed. Applicable constraints are defined in the corresponding standard",
"type": "string",
"pattern": "^BPNL[a-zA-Z0-9]{12}$"
},
"receiverBpn": {
"description": "The Business Partner Number of the receiving party. The value MUST be a valid BPN. BPNA and BPNS are not allowed. Applicable constraints are defined in the corresponding standard.",
"type": "string",
"pattern": "^BPNL[a-zA-Z0-9]{12}$"
},
"expectedResponseBy": {
"description": "Time zone aware timestamp holding the date and time by which the sending party expects a certain type of response from the receiving party. The meaning and interpretation of the fields'\''s value are context-bound and MUST therefore be defined by any business domain or platform capability making use of it. The value MUST be formatted according to the ISO 8601 standard",
"type": "string",
"pattern": "-?([1-9][0-9]{3,}|0[0-9]{3})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T(([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9](.[0-9]+)?|(24:00:00(.0+)?))(Z|(+|-)((0[0-9]|1[0-3]):[0-5][0-9]|14:00))?"
},
"relatedMessageId": {
"description": "Unique ID identifying a message somehow related to the current one",
"type": "string",
"pattern": "(^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)|(^urn:uuid:[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)"
},
"version": {
"description": "The unique identifier of the aspect model defining the structure and the semantics of the message'\''s header. The version number should reflect the versioning schema of aspect models in Catena-X.",
"type": "string",
"pattern": "^(0|[1-9][0-9]*).(0|[1-9][0-9]*).(0|[1-9][0-9]*)(-(0|[1-9A-Za-z-][0-9A-Za-z-]*)(.[0-9A-Za-z-]+)*)?([0-9A-Za-z-]+(.[0-9A-Za-z-]+)*)?$"
}
},
"required": [
"messageId",
"context",
"sentDateTime",
"senderBpn",
"receiverBpn",
"version"
]
}
},
"required": [
"rfqIdentification",
"rfqConfiguration",
"rfqSender",
"cxHeader"
]
}
}'
curl -L -X POST 'https://example.com/query-api/v3/:api-endpoint/request-for-quotation' \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
--data-raw '{
"filter": {
"description": "The request for quotation represents the data structure to configure a manufacturing request and send this to a supplier receive a quotation",
"type": "object",
"properties": {
"rfqIdentification": {
"description": "all properties necessary for identification of the request for quotation",
"type": "object",
"properties": {
"rfqSource": {
"description": "RFQ-Identification: digital address of the sender (e.g.token, IP address, link, user account)",
"type": "string"
},
"rfqId": {
"description": "RFQ-Identification: internal identifier in user account",
"type": "string"
},
"rfqName": {
"description": "RFQ-Identification: name for the request for user account management (usually name of the product to be manufactured)",
"type": "string"
},
"rfqDateTime": {
"description": "RFQ-Identification: date and time of the request in user account",
"type": "string",
"pattern": "-?([1-9][0-9]{3,}|0[0-9]{3})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T(([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9](.[0-9]+)?|(24:00:00(.0+)?))(Z|(+|-)((0[0-9]|1[0-3]):[0-5][0-9]|14:00))?"
},
"rfqVersion": {
"description": "RFQ-Identification: version of this request in case there were any changes",
"type": "string"
}
},
"required": [
"rfqId",
"rfqName",
"rfqDateTime",
"rfqVersion"
]
},
"rfqConfiguration": {
"description": "all information to configure a request for quotation",
"type": "object",
"properties": {
"cadFile": {
"description": "RFQ-Configuration: CAD file as geometry definition, e.g. step file",
"type": "object",
"properties": {
"fileType": {
"description": "RFQ-Configuration: file format",
"type": "string"
},
"filePath": {
"description": "path or address to the file ",
"type": "string"
},
"fileName": {
"description": "name of the file",
"type": "string"
},
"fileObject": {
"description": "the file object itself, in case this could be sent via the API",
"type": "object",
"properties": {}
}
},
"required": [
"fileType",
"fileName"
]
},
"parts": {
"description": "RFQ-Configuration: list of parts contained in the CAD file",
"type": "object",
"properties": {
"partId": {
"description": "RFQ-PartConfiguration: identifier of the part from CAD File",
"type": "string"
},
"partName": {
"description": "RFQ-PartConfiguration: name of the part in CAD file. In case the CAD file has only one part, this could also be the file name.",
"type": "string"
},
"manufacturingDomain": {
"description": "RFQ-PartConfiguration: domain of required process (e.g. subtractive manufacturing, additive manufacturing, assembly)",
"type": "string"
},
"generalTolerance": {
"description": "RFQ-PartConfiguration: selection of defined tolerance classes",
"type": "string"
},
"additionalRequirements": {
"description": "RFQ-PartConfiguration: specific requirements e.g. to guarantee quality, like premium quality check or standard quality check or test part required (makes only sense for batch)",
"type": "string"
},
"material": {
"description": "RFQ-PartConfiguration: material definition with further information",
"type": "object",
"properties": {
"materialProperties": {
"description": "material definition with additional detail properties with name, value and value type, like name= density, value=2.7, type=g/m3 or name= chemical term, value=AlMgMn, type=periodic table",
"type": "object",
"properties": {
"value": {
"description": "value to detail the part material item",
"type": "string"
},
"valueType": {
"description": "value type to specify the value of the property",
"type": "string"
},
"propertyName": {
"description": "name of the property",
"type": "string"
}
},
"required": [
"value",
"valueType",
"propertyName"
]
},
"materialFamily": {
"description": "definition of material family for preselection",
"type": "string"
}
},
"required": [
"materialProperties"
]
},
"partQuantity": {
"description": "RFQ-PartConfiguration: Quantity of which the part item is assembled into the parent item (within the CAD File). In general it is '\''1'\'' for serialized parts.",
"type": "object",
"properties": {
"quantityNumber": {
"description": "The number of objects related to the measurement unit",
"type": "number"
},
"measurementUnit": {
"description": "Unit of Measurement for the quantity of serialized objects",
"type": "string",
"pattern": "[a-zA-Z]*:[a-zA-Z]+"
}
},
"required": [
"quantityNumber",
"measurementUnit"
]
},
"billOfProcess": {
"description": "RFQ-PartConfiguration: list of process steps for part to be manufactured",
"type": "object",
"properties": {
"process": {
"description": "List that contains all manufacturing steps of a product, whereat each manufacturing step refers to exactly one capability. This list contains all process steps that are required to manufacture the product, specified with the bill of process ",
"type": "array",
"items": {
"description": "Entity to characterize single process steps",
"type": "object",
"properties": {
"processStepIdentifier": {
"description": "Unique identifier for a concrete process step",
"type": "array",
"items": {
"type": "string"
}
},
"inputParameters": {
"description": "Optional list of parameters that are required to execute the corresponding process step",
"type": "array",
"items": {
"description": "Generic entity to characterize parameters. It distinguished four cases: a parameter without a value, a parameter with a value, a parameter with a value range and a parameter with tolerances ",
"type": "object",
"properties": {
"name": {
"description": "Name of the parameter",
"type": "string"
},
"value": {
"description": "Value of the parameter",
"type": "string"
},
"semanticReference": {
"description": "Reference to a semantic namespace in which the type of the parameter is defined",
"type": "array",
"items": {
"type": "string"
}
},
"parameterKey": {
"description": "Enumeration that is used to distinguish whether the parameter has no value, has a value, has a value range or has a value with tolerances",
"type": "string",
"enum": [
"HasValue",
"HasNoValue",
"HasValueRange",
"HasTolerances"
]
},
"valueRangeList": {
"description": "List with value ranges for a parameter",
"type": "array",
"items": {
"description": "Entity for each value range item",
"type": "object",
"properties": {
"lowerValue": {
"description": "Lower border of a value range item",
"type": "string"
},
"upperValue": {
"description": "Upper border for a value range item",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerValue",
"upperValue"
]
}
},
"tolerances": {
"description": "Tolerances for a parameter ",
"type": "array",
"items": {
"description": "Entity to express the tolerances of a parameter",
"type": "object",
"properties": {
"lowerLimit": {
"description": "The lower direct limit of the tolerance",
"type": "string"
},
"upperLimit": {
"description": "Upper direct limit of the tolerance",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerLimit",
"upperLimit"
]
}
}
},
"required": [
"name",
"semanticReference",
"parameterKey"
]
}
},
"outputParameters": {
"description": "Optional list of parameters that are returned from the process step and can be used as inputParameters for subsequent steps",
"type": "array",
"items": {
"description": "Generic entity to characterize parameters. It distinguished four cases: a parameter without a value, a parameter with a value, a parameter with a value range and a parameter with tolerances ",
"type": "object",
"properties": {
"name": {
"description": "Name of the parameter",
"type": "string"
},
"value": {
"description": "Value of the parameter",
"type": "string"
},
"semanticReference": {
"description": "Reference to a semantic namespace in which the type of the parameter is defined",
"type": "array",
"items": {
"type": "string"
}
},
"parameterKey": {
"description": "Enumeration that is used to distinguish whether the parameter has no value, has a value, has a value range or has a value with tolerances",
"type": "string",
"enum": [
"HasValue",
"HasNoValue",
"HasValueRange",
"HasTolerances"
]
},
"valueRangeList": {
"description": "List with value ranges for a parameter",
"type": "array",
"items": {
"description": "Entity for each value range item",
"type": "object",
"properties": {
"lowerValue": {
"description": "Lower border of a value range item",
"type": "string"
},
"upperValue": {
"description": "Upper border for a value range item",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerValue",
"upperValue"
]
}
},
"tolerances": {
"description": "Tolerances for a parameter ",
"type": "array",
"items": {
"description": "Entity to express the tolerances of a parameter",
"type": "object",
"properties": {
"lowerLimit": {
"description": "The lower direct limit of the tolerance",
"type": "string"
},
"upperLimit": {
"description": "Upper direct limit of the tolerance",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerLimit",
"upperLimit"
]
}
}
},
"required": [
"name",
"semanticReference",
"parameterKey"
]
}
},
"precedenceRelation": {
"description": "List of alternative process steps from which the manufacturer has to select exactly one step to be executed. In case of no alternative process step, the list features only one element. In case of the last element, the property is not used, since the process step has no successor",
"type": "array",
"items": {
"description": "List of process steps that must be executed in parallel",
"type": "object",
"properties": {
"precedenceElements": {
"description": "List process steps that must be executed in parallel",
"type": "array",
"items": {
"description": "Entity to link the current process step to its successors",
"type": "object",
"properties": {
"successor": {
"description": "List of subsequent process step which can be executed in any order ",
"type": "array",
"items": {
"type": "string"
}
}
},
"required": [
"successor"
]
}
}
},
"required": [
"precedenceElements"
]
}
},
"childProcessSteps": {
"description": "List of child processes that need to be executed to complete the parent process step. It enables the expression of hierarchies between capabilities, e.g. a transport capability needs to execute at least a pick, a move and a place capability",
"type": "array",
"items": {
"type": "string"
}
},
"processStepType": {
"description": "Distinguishes process steps based on whether there are the first or last process step to be executed, or if they are a subprocess step, which subdivides a higher-level process step into smaller process steps",
"type": "string",
"enum": [
"IsFirstElement",
"IsLastElement",
"IsProcessElement",
"IsSubprocessElement"
]
},
"capabilityId": {
"description": "Locally unique identifier for a capability.",
"type": "string"
}
},
"required": [
"processStepIdentifier",
"processStepType",
"capabilityId"
]
}
},
"productVersion": {
"description": "Version of the product whose manufacturing steps are specified with the bill of process. It can for example specify a concrete variant of a product",
"type": "string"
},
"productName": {
"description": "Name of the product whose production steps are specified within the bill of process",
"type": "string"
},
"billOfProcessIdentification": {
"description": "Unique identifier for a bill of process that can be used to reference instances of the bill of process",
"type": "string"
},
"version": {
"description": "The unique identifier of the aspect model defining the structure and the semantics of the message'\''s header. The version number should reflect the versioning schema of aspect models in Catena-X.",
"type": "string",
"pattern": "^(0|[1-9][0-9]*).(0|[1-9][0-9]*).(0|[1-9][0-9]*)(-(0|[1-9A-Za-z-][0-9A-Za-z-]*)(.[0-9A-Za-z-]+)*)?([0-9A-Za-z-]+(.[0-9A-Za-z-]+)*)?$"
}
},
"required": [
"process",
"productVersion",
"productName",
"billOfProcessIdentification",
"version"
]
}
},
"required": [
"partId",
"partName",
"generalTolerance",
"material",
"partQuantity"
]
},
"firstDeliveryDate": {
"description": "RFQ-Configuration: Date of desired, first, but not must delivery",
"type": "string",
"format": "date"
},
"lastDeliveryDate": {
"description": "RFQ-Configuration: date of required and last acceptable delivery",
"type": "string",
"format": "date"
},
"additionalComments": {
"description": "RFQ-Configuration: placeholder for any kind of additional comments",
"type": "string"
},
"additionalFiles": {
"description": "RFQ-Configuration: in case there are additional documents or files to share (like e.g. technical drawings)",
"type": "object",
"properties": {
"fileType": {
"description": "RFQ-Configuration: file format",
"type": "string"
},
"filePath": {
"description": "path or address to the file ",
"type": "string"
},
"fileName": {
"description": "name of the file",
"type": "string"
},
"fileObject": {
"description": "the file object itself, in case this could be sent via the API",
"type": "object",
"properties": {}
}
},
"required": [
"fileType",
"fileName"
]
},
"orderQuantity": {
"description": "RFQ-Configuration: quantity at all, valid for complete order (usually number of products to be ordered)",
"type": "object",
"properties": {
"quantityNumber": {
"description": "The number of objects related to the measurement unit",
"type": "number"
},
"measurementUnit": {
"description": "Unit of Measurement for the quantity of serialized objects",
"type": "string",
"pattern": "[a-zA-Z]*:[a-zA-Z]+"
}
},
"required": [
"quantityNumber",
"measurementUnit"
]
}
},
"required": [
"cadFile",
"parts",
"lastDeliveryDate",
"orderQuantity"
]
},
"rfqSender": {
"description": "all data about sender of request for quotation, important for offer and delivery",
"type": "object",
"properties": {
"senderName": {
"description": "RFQ-Sender: name of the sender",
"type": "string"
},
"senderAdress": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, address of sender",
"type": "string"
},
"senderCompanyName": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, company name of sender",
"type": "string"
},
"senderEMail": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, e-mail address of sender",
"type": "string"
},
"senderPhoneNumber": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, phone number of sender",
"type": "string"
},
"senderAccountAddress": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, address of sender for account",
"type": "string"
},
"senderDeliveryAddress": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, address of sender for delivery",
"type": "string"
},
"deliveryRequirements": {
"description": "RFQ-Sender: filled by customer, any kind of delivery requirements",
"type": "string"
}
},
"required": [
"senderName",
"senderAdress",
"senderEMail",
"senderPhoneNumber",
"senderAccountAddress",
"senderDeliveryAddress"
]
},
"cxHeader": {
"description": "header information by Catena-X",
"type": "object",
"properties": {
"messageId": {
"description": "Unique ID identifying the message. The purpose of the ID is to uniquely identify a single message, therefore it MUST not be reused.",
"type": "string",
"pattern": "(^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)|(^urn:uuid:[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)"
},
"context": {
"description": "Information about the context the message should be considered in.\nThe value MUST consist of two parts: an identifier of the context (e.g. business domain, etc.) followed by a version number.\nBoth the identifier and the version number MUST correspond to the content of the message.\nIf the content of a message is described by an aspect model available in the Catena-X Semantic Hub, then the unique identifier of this semantic model (e.g. urn:samm:io.catenax.<ASPECT-MODEL-NAME>:1.x.x) MUST be used as a value of the context field. This is considered the default case.\nIn all other cases the value of the context field MUST follow the pattern <domain>-<subdomain>-<object>:<[major] version> (e.g. TRACE-QM-Alert:1.x.x).\nVersioning only refers to major versions in both default and fallback cases.\nNote: The version of the message'\''s header is specified in the version field.",
"type": "string"
},
"sentDateTime": {
"description": "Time zone aware timestamp holding the date and the time the message was sent by the sending party. The value MUST be formatted according to the ISO 8601 standard",
"type": "string",
"pattern": "-?([1-9][0-9]{3,}|0[0-9]{3})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T(([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9](.[0-9]+)?|(24:00:00(.0+)?))(Z|(+|-)((0[0-9]|1[0-3]):[0-5][0-9]|14:00))?"
},
"senderBpn": {
"description": "The Business Partner Number of the sending party. The value MUST be a valid BPN. BPNA and BPNS are not allowed. Applicable constraints are defined in the corresponding standard",
"type": "string",
"pattern": "^BPNL[a-zA-Z0-9]{12}$"
},
"receiverBpn": {
"description": "The Business Partner Number of the receiving party. The value MUST be a valid BPN. BPNA and BPNS are not allowed. Applicable constraints are defined in the corresponding standard.",
"type": "string",
"pattern": "^BPNL[a-zA-Z0-9]{12}$"
},
"expectedResponseBy": {
"description": "Time zone aware timestamp holding the date and time by which the sending party expects a certain type of response from the receiving party. The meaning and interpretation of the fields'\''s value are context-bound and MUST therefore be defined by any business domain or platform capability making use of it. The value MUST be formatted according to the ISO 8601 standard",
"type": "string",
"pattern": "-?([1-9][0-9]{3,}|0[0-9]{3})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T(([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9](.[0-9]+)?|(24:00:00(.0+)?))(Z|(+|-)((0[0-9]|1[0-3]):[0-5][0-9]|14:00))?"
},
"relatedMessageId": {
"description": "Unique ID identifying a message somehow related to the current one",
"type": "string",
"pattern": "(^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)|(^urn:uuid:[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)"
},
"version": {
"description": "The unique identifier of the aspect model defining the structure and the semantics of the message'\''s header. The version number should reflect the versioning schema of aspect models in Catena-X.",
"type": "string",
"pattern": "^(0|[1-9][0-9]*).(0|[1-9][0-9]*).(0|[1-9][0-9]*)(-(0|[1-9A-Za-z-][0-9A-Za-z-]*)(.[0-9A-Za-z-]+)*)?([0-9A-Za-z-]+(.[0-9A-Za-z-]+)*)?$"
}
},
"required": [
"messageId",
"context",
"sentDateTime",
"senderBpn",
"receiverBpn",
"version"
]
}
},
"required": [
"rfqIdentification",
"rfqConfiguration",
"rfqSender",
"cxHeader"
]
}
}'
curl -L -X POST 'https://example.com/query-api/v3/:api-endpoint/request-for-quotation' \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
--data-raw '{
"filter": {
"description": "The request for quotation represents the data structure to configure a manufacturing request and send this to a supplier receive a quotation",
"type": "object",
"properties": {
"rfqIdentification": {
"description": "all properties necessary for identification of the request for quotation",
"type": "object",
"properties": {
"rfqSource": {
"description": "RFQ-Identification: digital address of the sender (e.g.token, IP address, link, user account)",
"type": "string"
},
"rfqId": {
"description": "RFQ-Identification: internal identifier in user account",
"type": "string"
},
"rfqName": {
"description": "RFQ-Identification: name for the request for user account management (usually name of the product to be manufactured)",
"type": "string"
},
"rfqDateTime": {
"description": "RFQ-Identification: date and time of the request in user account",
"type": "string",
"pattern": "-?([1-9][0-9]{3,}|0[0-9]{3})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T(([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9](.[0-9]+)?|(24:00:00(.0+)?))(Z|(+|-)((0[0-9]|1[0-3]):[0-5][0-9]|14:00))?"
},
"rfqVersion": {
"description": "RFQ-Identification: version of this request in case there were any changes",
"type": "string"
}
},
"required": [
"rfqId",
"rfqName",
"rfqDateTime",
"rfqVersion"
]
},
"rfqConfiguration": {
"description": "all information to configure a request for quotation",
"type": "object",
"properties": {
"cadFile": {
"description": "RFQ-Configuration: CAD file as geometry definition, e.g. step file",
"type": "object",
"properties": {
"fileType": {
"description": "RFQ-Configuration: file format",
"type": "string"
},
"filePath": {
"description": "path or address to the file ",
"type": "string"
},
"fileName": {
"description": "name of the file",
"type": "string"
},
"fileObject": {
"description": "the file object itself, in case this could be sent via the API",
"type": "object",
"properties": {}
}
},
"required": [
"fileType",
"fileName"
]
},
"parts": {
"description": "RFQ-Configuration: list of parts contained in the CAD file",
"type": "object",
"properties": {
"partId": {
"description": "RFQ-PartConfiguration: identifier of the part from CAD File",
"type": "string"
},
"partName": {
"description": "RFQ-PartConfiguration: name of the part in CAD file. In case the CAD file has only one part, this could also be the file name.",
"type": "string"
},
"manufacturingDomain": {
"description": "RFQ-PartConfiguration: domain of required process (e.g. subtractive manufacturing, additive manufacturing, assembly)",
"type": "string"
},
"generalTolerance": {
"description": "RFQ-PartConfiguration: selection of defined tolerance classes",
"type": "string"
},
"additionalRequirements": {
"description": "RFQ-PartConfiguration: specific requirements e.g. to guarantee quality, like premium quality check or standard quality check or test part required (makes only sense for batch)",
"type": "string"
},
"material": {
"description": "RFQ-PartConfiguration: material definition with further information",
"type": "object",
"properties": {
"materialProperties": {
"description": "material definition with additional detail properties with name, value and value type, like name= density, value=2.7, type=g/m3 or name= chemical term, value=AlMgMn, type=periodic table",
"type": "object",
"properties": {
"value": {
"description": "value to detail the part material item",
"type": "string"
},
"valueType": {
"description": "value type to specify the value of the property",
"type": "string"
},
"propertyName": {
"description": "name of the property",
"type": "string"
}
},
"required": [
"value",
"valueType",
"propertyName"
]
},
"materialFamily": {
"description": "definition of material family for preselection",
"type": "string"
}
},
"required": [
"materialProperties"
]
},
"partQuantity": {
"description": "RFQ-PartConfiguration: Quantity of which the part item is assembled into the parent item (within the CAD File). In general it is '\''1'\'' for serialized parts.",
"type": "object",
"properties": {
"quantityNumber": {
"description": "The number of objects related to the measurement unit",
"type": "number"
},
"measurementUnit": {
"description": "Unit of Measurement for the quantity of serialized objects",
"type": "string",
"pattern": "[a-zA-Z]*:[a-zA-Z]+"
}
},
"required": [
"quantityNumber",
"measurementUnit"
]
},
"billOfProcess": {
"description": "RFQ-PartConfiguration: list of process steps for part to be manufactured",
"type": "object",
"properties": {
"process": {
"description": "List that contains all manufacturing steps of a product, whereat each manufacturing step refers to exactly one capability. This list contains all process steps that are required to manufacture the product, specified with the bill of process ",
"type": "array",
"items": {
"description": "Entity to characterize single process steps",
"type": "object",
"properties": {
"processStepIdentifier": {
"description": "Unique identifier for a concrete process step",
"type": "array",
"items": {
"type": "string"
}
},
"inputParameters": {
"description": "Optional list of parameters that are required to execute the corresponding process step",
"type": "array",
"items": {
"description": "Generic entity to characterize parameters. It distinguished four cases: a parameter without a value, a parameter with a value, a parameter with a value range and a parameter with tolerances ",
"type": "object",
"properties": {
"name": {
"description": "Name of the parameter",
"type": "string"
},
"value": {
"description": "Value of the parameter",
"type": "string"
},
"semanticReference": {
"description": "Reference to a semantic namespace in which the type of the parameter is defined",
"type": "array",
"items": {
"type": "string"
}
},
"parameterKey": {
"description": "Enumeration that is used to distinguish whether the parameter has no value, has a value, has a value range or has a value with tolerances",
"type": "string",
"enum": [
"HasValue",
"HasNoValue",
"HasValueRange",
"HasTolerances"
]
},
"valueRangeList": {
"description": "List with value ranges for a parameter",
"type": "array",
"items": {
"description": "Entity for each value range item",
"type": "object",
"properties": {
"lowerValue": {
"description": "Lower border of a value range item",
"type": "string"
},
"upperValue": {
"description": "Upper border for a value range item",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerValue",
"upperValue"
]
}
},
"tolerances": {
"description": "Tolerances for a parameter ",
"type": "array",
"items": {
"description": "Entity to express the tolerances of a parameter",
"type": "object",
"properties": {
"lowerLimit": {
"description": "The lower direct limit of the tolerance",
"type": "string"
},
"upperLimit": {
"description": "Upper direct limit of the tolerance",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerLimit",
"upperLimit"
]
}
}
},
"required": [
"name",
"semanticReference",
"parameterKey"
]
}
},
"outputParameters": {
"description": "Optional list of parameters that are returned from the process step and can be used as inputParameters for subsequent steps",
"type": "array",
"items": {
"description": "Generic entity to characterize parameters. It distinguished four cases: a parameter without a value, a parameter with a value, a parameter with a value range and a parameter with tolerances ",
"type": "object",
"properties": {
"name": {
"description": "Name of the parameter",
"type": "string"
},
"value": {
"description": "Value of the parameter",
"type": "string"
},
"semanticReference": {
"description": "Reference to a semantic namespace in which the type of the parameter is defined",
"type": "array",
"items": {
"type": "string"
}
},
"parameterKey": {
"description": "Enumeration that is used to distinguish whether the parameter has no value, has a value, has a value range or has a value with tolerances",
"type": "string",
"enum": [
"HasValue",
"HasNoValue",
"HasValueRange",
"HasTolerances"
]
},
"valueRangeList": {
"description": "List with value ranges for a parameter",
"type": "array",
"items": {
"description": "Entity for each value range item",
"type": "object",
"properties": {
"lowerValue": {
"description": "Lower border of a value range item",
"type": "string"
},
"upperValue": {
"description": "Upper border for a value range item",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerValue",
"upperValue"
]
}
},
"tolerances": {
"description": "Tolerances for a parameter ",
"type": "array",
"items": {
"description": "Entity to express the tolerances of a parameter",
"type": "object",
"properties": {
"lowerLimit": {
"description": "The lower direct limit of the tolerance",
"type": "string"
},
"upperLimit": {
"description": "Upper direct limit of the tolerance",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerLimit",
"upperLimit"
]
}
}
},
"required": [
"name",
"semanticReference",
"parameterKey"
]
}
},
"precedenceRelation": {
"description": "List of alternative process steps from which the manufacturer has to select exactly one step to be executed. In case of no alternative process step, the list features only one element. In case of the last element, the property is not used, since the process step has no successor",
"type": "array",
"items": {
"description": "List of process steps that must be executed in parallel",
"type": "object",
"properties": {
"precedenceElements": {
"description": "List process steps that must be executed in parallel",
"type": "array",
"items": {
"description": "Entity to link the current process step to its successors",
"type": "object",
"properties": {
"successor": {
"description": "List of subsequent process step which can be executed in any order ",
"type": "array",
"items": {
"type": "string"
}
}
},
"required": [
"successor"
]
}
}
},
"required": [
"precedenceElements"
]
}
},
"childProcessSteps": {
"description": "List of child processes that need to be executed to complete the parent process step. It enables the expression of hierarchies between capabilities, e.g. a transport capability needs to execute at least a pick, a move and a place capability",
"type": "array",
"items": {
"type": "string"
}
},
"processStepType": {
"description": "Distinguishes process steps based on whether there are the first or last process step to be executed, or if they are a subprocess step, which subdivides a higher-level process step into smaller process steps",
"type": "string",
"enum": [
"IsFirstElement",
"IsLastElement",
"IsProcessElement",
"IsSubprocessElement"
]
},
"capabilityId": {
"description": "Locally unique identifier for a capability.",
"type": "string"
}
},
"required": [
"processStepIdentifier",
"processStepType",
"capabilityId"
]
}
},
"productVersion": {
"description": "Version of the product whose manufacturing steps are specified with the bill of process. It can for example specify a concrete variant of a product",
"type": "string"
},
"productName": {
"description": "Name of the product whose production steps are specified within the bill of process",
"type": "string"
},
"billOfProcessIdentification": {
"description": "Unique identifier for a bill of process that can be used to reference instances of the bill of process",
"type": "string"
},
"version": {
"description": "The unique identifier of the aspect model defining the structure and the semantics of the message'\''s header. The version number should reflect the versioning schema of aspect models in Catena-X.",
"type": "string",
"pattern": "^(0|[1-9][0-9]*).(0|[1-9][0-9]*).(0|[1-9][0-9]*)(-(0|[1-9A-Za-z-][0-9A-Za-z-]*)(.[0-9A-Za-z-]+)*)?([0-9A-Za-z-]+(.[0-9A-Za-z-]+)*)?$"
}
},
"required": [
"process",
"productVersion",
"productName",
"billOfProcessIdentification",
"version"
]
}
},
"required": [
"partId",
"partName",
"generalTolerance",
"material",
"partQuantity"
]
},
"firstDeliveryDate": {
"description": "RFQ-Configuration: Date of desired, first, but not must delivery",
"type": "string",
"format": "date"
},
"lastDeliveryDate": {
"description": "RFQ-Configuration: date of required and last acceptable delivery",
"type": "string",
"format": "date"
},
"additionalComments": {
"description": "RFQ-Configuration: placeholder for any kind of additional comments",
"type": "string"
},
"additionalFiles": {
"description": "RFQ-Configuration: in case there are additional documents or files to share (like e.g. technical drawings)",
"type": "object",
"properties": {
"fileType": {
"description": "RFQ-Configuration: file format",
"type": "string"
},
"filePath": {
"description": "path or address to the file ",
"type": "string"
},
"fileName": {
"description": "name of the file",
"type": "string"
},
"fileObject": {
"description": "the file object itself, in case this could be sent via the API",
"type": "object",
"properties": {}
}
},
"required": [
"fileType",
"fileName"
]
},
"orderQuantity": {
"description": "RFQ-Configuration: quantity at all, valid for complete order (usually number of products to be ordered)",
"type": "object",
"properties": {
"quantityNumber": {
"description": "The number of objects related to the measurement unit",
"type": "number"
},
"measurementUnit": {
"description": "Unit of Measurement for the quantity of serialized objects",
"type": "string",
"pattern": "[a-zA-Z]*:[a-zA-Z]+"
}
},
"required": [
"quantityNumber",
"measurementUnit"
]
}
},
"required": [
"cadFile",
"parts",
"lastDeliveryDate",
"orderQuantity"
]
},
"rfqSender": {
"description": "all data about sender of request for quotation, important for offer and delivery",
"type": "object",
"properties": {
"senderName": {
"description": "RFQ-Sender: name of the sender",
"type": "string"
},
"senderAdress": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, address of sender",
"type": "string"
},
"senderCompanyName": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, company name of sender",
"type": "string"
},
"senderEMail": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, e-mail address of sender",
"type": "string"
},
"senderPhoneNumber": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, phone number of sender",
"type": "string"
},
"senderAccountAddress": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, address of sender for account",
"type": "string"
},
"senderDeliveryAddress": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, address of sender for delivery",
"type": "string"
},
"deliveryRequirements": {
"description": "RFQ-Sender: filled by customer, any kind of delivery requirements",
"type": "string"
}
},
"required": [
"senderName",
"senderAdress",
"senderEMail",
"senderPhoneNumber",
"senderAccountAddress",
"senderDeliveryAddress"
]
},
"cxHeader": {
"description": "header information by Catena-X",
"type": "object",
"properties": {
"messageId": {
"description": "Unique ID identifying the message. The purpose of the ID is to uniquely identify a single message, therefore it MUST not be reused.",
"type": "string",
"pattern": "(^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)|(^urn:uuid:[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)"
},
"context": {
"description": "Information about the context the message should be considered in.\nThe value MUST consist of two parts: an identifier of the context (e.g. business domain, etc.) followed by a version number.\nBoth the identifier and the version number MUST correspond to the content of the message.\nIf the content of a message is described by an aspect model available in the Catena-X Semantic Hub, then the unique identifier of this semantic model (e.g. urn:samm:io.catenax.<ASPECT-MODEL-NAME>:1.x.x) MUST be used as a value of the context field. This is considered the default case.\nIn all other cases the value of the context field MUST follow the pattern <domain>-<subdomain>-<object>:<[major] version> (e.g. TRACE-QM-Alert:1.x.x).\nVersioning only refers to major versions in both default and fallback cases.\nNote: The version of the message'\''s header is specified in the version field.",
"type": "string"
},
"sentDateTime": {
"description": "Time zone aware timestamp holding the date and the time the message was sent by the sending party. The value MUST be formatted according to the ISO 8601 standard",
"type": "string",
"pattern": "-?([1-9][0-9]{3,}|0[0-9]{3})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T(([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9](.[0-9]+)?|(24:00:00(.0+)?))(Z|(+|-)((0[0-9]|1[0-3]):[0-5][0-9]|14:00))?"
},
"senderBpn": {
"description": "The Business Partner Number of the sending party. The value MUST be a valid BPN. BPNA and BPNS are not allowed. Applicable constraints are defined in the corresponding standard",
"type": "string",
"pattern": "^BPNL[a-zA-Z0-9]{12}$"
},
"receiverBpn": {
"description": "The Business Partner Number of the receiving party. The value MUST be a valid BPN. BPNA and BPNS are not allowed. Applicable constraints are defined in the corresponding standard.",
"type": "string",
"pattern": "^BPNL[a-zA-Z0-9]{12}$"
},
"expectedResponseBy": {
"description": "Time zone aware timestamp holding the date and time by which the sending party expects a certain type of response from the receiving party. The meaning and interpretation of the fields'\''s value are context-bound and MUST therefore be defined by any business domain or platform capability making use of it. The value MUST be formatted according to the ISO 8601 standard",
"type": "string",
"pattern": "-?([1-9][0-9]{3,}|0[0-9]{3})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T(([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9](.[0-9]+)?|(24:00:00(.0+)?))(Z|(+|-)((0[0-9]|1[0-3]):[0-5][0-9]|14:00))?"
},
"relatedMessageId": {
"description": "Unique ID identifying a message somehow related to the current one",
"type": "string",
"pattern": "(^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)|(^urn:uuid:[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)"
},
"version": {
"description": "The unique identifier of the aspect model defining the structure and the semantics of the message'\''s header. The version number should reflect the versioning schema of aspect models in Catena-X.",
"type": "string",
"pattern": "^(0|[1-9][0-9]*).(0|[1-9][0-9]*).(0|[1-9][0-9]*)(-(0|[1-9A-Za-z-][0-9A-Za-z-]*)(.[0-9A-Za-z-]+)*)?([0-9A-Za-z-]+(.[0-9A-Za-z-]+)*)?$"
}
},
"required": [
"messageId",
"context",
"sentDateTime",
"senderBpn",
"receiverBpn",
"version"
]
}
},
"required": [
"rfqIdentification",
"rfqConfiguration",
"rfqSender",
"cxHeader"
]
}
}'
curl -L -X POST 'https://example.com/query-api/v3/:api-endpoint/request-for-quotation' \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
--data-raw '{
"filter": {
"description": "The request for quotation represents the data structure to configure a manufacturing request and send this to a supplier receive a quotation",
"type": "object",
"properties": {
"rfqIdentification": {
"description": "all properties necessary for identification of the request for quotation",
"type": "object",
"properties": {
"rfqSource": {
"description": "RFQ-Identification: digital address of the sender (e.g.token, IP address, link, user account)",
"type": "string"
},
"rfqId": {
"description": "RFQ-Identification: internal identifier in user account",
"type": "string"
},
"rfqName": {
"description": "RFQ-Identification: name for the request for user account management (usually name of the product to be manufactured)",
"type": "string"
},
"rfqDateTime": {
"description": "RFQ-Identification: date and time of the request in user account",
"type": "string",
"pattern": "-?([1-9][0-9]{3,}|0[0-9]{3})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T(([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9](.[0-9]+)?|(24:00:00(.0+)?))(Z|(+|-)((0[0-9]|1[0-3]):[0-5][0-9]|14:00))?"
},
"rfqVersion": {
"description": "RFQ-Identification: version of this request in case there were any changes",
"type": "string"
}
},
"required": [
"rfqId",
"rfqName",
"rfqDateTime",
"rfqVersion"
]
},
"rfqConfiguration": {
"description": "all information to configure a request for quotation",
"type": "object",
"properties": {
"cadFile": {
"description": "RFQ-Configuration: CAD file as geometry definition, e.g. step file",
"type": "object",
"properties": {
"fileType": {
"description": "RFQ-Configuration: file format",
"type": "string"
},
"filePath": {
"description": "path or address to the file ",
"type": "string"
},
"fileName": {
"description": "name of the file",
"type": "string"
},
"fileObject": {
"description": "the file object itself, in case this could be sent via the API",
"type": "object",
"properties": {}
}
},
"required": [
"fileType",
"fileName"
]
},
"parts": {
"description": "RFQ-Configuration: list of parts contained in the CAD file",
"type": "object",
"properties": {
"partId": {
"description": "RFQ-PartConfiguration: identifier of the part from CAD File",
"type": "string"
},
"partName": {
"description": "RFQ-PartConfiguration: name of the part in CAD file. In case the CAD file has only one part, this could also be the file name.",
"type": "string"
},
"manufacturingDomain": {
"description": "RFQ-PartConfiguration: domain of required process (e.g. subtractive manufacturing, additive manufacturing, assembly)",
"type": "string"
},
"generalTolerance": {
"description": "RFQ-PartConfiguration: selection of defined tolerance classes",
"type": "string"
},
"additionalRequirements": {
"description": "RFQ-PartConfiguration: specific requirements e.g. to guarantee quality, like premium quality check or standard quality check or test part required (makes only sense for batch)",
"type": "string"
},
"material": {
"description": "RFQ-PartConfiguration: material definition with further information",
"type": "object",
"properties": {
"materialProperties": {
"description": "material definition with additional detail properties with name, value and value type, like name= density, value=2.7, type=g/m3 or name= chemical term, value=AlMgMn, type=periodic table",
"type": "object",
"properties": {
"value": {
"description": "value to detail the part material item",
"type": "string"
},
"valueType": {
"description": "value type to specify the value of the property",
"type": "string"
},
"propertyName": {
"description": "name of the property",
"type": "string"
}
},
"required": [
"value",
"valueType",
"propertyName"
]
},
"materialFamily": {
"description": "definition of material family for preselection",
"type": "string"
}
},
"required": [
"materialProperties"
]
},
"partQuantity": {
"description": "RFQ-PartConfiguration: Quantity of which the part item is assembled into the parent item (within the CAD File). In general it is '\''1'\'' for serialized parts.",
"type": "object",
"properties": {
"quantityNumber": {
"description": "The number of objects related to the measurement unit",
"type": "number"
},
"measurementUnit": {
"description": "Unit of Measurement for the quantity of serialized objects",
"type": "string",
"pattern": "[a-zA-Z]*:[a-zA-Z]+"
}
},
"required": [
"quantityNumber",
"measurementUnit"
]
},
"billOfProcess": {
"description": "RFQ-PartConfiguration: list of process steps for part to be manufactured",
"type": "object",
"properties": {
"process": {
"description": "List that contains all manufacturing steps of a product, whereat each manufacturing step refers to exactly one capability. This list contains all process steps that are required to manufacture the product, specified with the bill of process ",
"type": "array",
"items": {
"description": "Entity to characterize single process steps",
"type": "object",
"properties": {
"processStepIdentifier": {
"description": "Unique identifier for a concrete process step",
"type": "array",
"items": {
"type": "string"
}
},
"inputParameters": {
"description": "Optional list of parameters that are required to execute the corresponding process step",
"type": "array",
"items": {
"description": "Generic entity to characterize parameters. It distinguished four cases: a parameter without a value, a parameter with a value, a parameter with a value range and a parameter with tolerances ",
"type": "object",
"properties": {
"name": {
"description": "Name of the parameter",
"type": "string"
},
"value": {
"description": "Value of the parameter",
"type": "string"
},
"semanticReference": {
"description": "Reference to a semantic namespace in which the type of the parameter is defined",
"type": "array",
"items": {
"type": "string"
}
},
"parameterKey": {
"description": "Enumeration that is used to distinguish whether the parameter has no value, has a value, has a value range or has a value with tolerances",
"type": "string",
"enum": [
"HasValue",
"HasNoValue",
"HasValueRange",
"HasTolerances"
]
},
"valueRangeList": {
"description": "List with value ranges for a parameter",
"type": "array",
"items": {
"description": "Entity for each value range item",
"type": "object",
"properties": {
"lowerValue": {
"description": "Lower border of a value range item",
"type": "string"
},
"upperValue": {
"description": "Upper border for a value range item",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerValue",
"upperValue"
]
}
},
"tolerances": {
"description": "Tolerances for a parameter ",
"type": "array",
"items": {
"description": "Entity to express the tolerances of a parameter",
"type": "object",
"properties": {
"lowerLimit": {
"description": "The lower direct limit of the tolerance",
"type": "string"
},
"upperLimit": {
"description": "Upper direct limit of the tolerance",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerLimit",
"upperLimit"
]
}
}
},
"required": [
"name",
"semanticReference",
"parameterKey"
]
}
},
"outputParameters": {
"description": "Optional list of parameters that are returned from the process step and can be used as inputParameters for subsequent steps",
"type": "array",
"items": {
"description": "Generic entity to characterize parameters. It distinguished four cases: a parameter without a value, a parameter with a value, a parameter with a value range and a parameter with tolerances ",
"type": "object",
"properties": {
"name": {
"description": "Name of the parameter",
"type": "string"
},
"value": {
"description": "Value of the parameter",
"type": "string"
},
"semanticReference": {
"description": "Reference to a semantic namespace in which the type of the parameter is defined",
"type": "array",
"items": {
"type": "string"
}
},
"parameterKey": {
"description": "Enumeration that is used to distinguish whether the parameter has no value, has a value, has a value range or has a value with tolerances",
"type": "string",
"enum": [
"HasValue",
"HasNoValue",
"HasValueRange",
"HasTolerances"
]
},
"valueRangeList": {
"description": "List with value ranges for a parameter",
"type": "array",
"items": {
"description": "Entity for each value range item",
"type": "object",
"properties": {
"lowerValue": {
"description": "Lower border of a value range item",
"type": "string"
},
"upperValue": {
"description": "Upper border for a value range item",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerValue",
"upperValue"
]
}
},
"tolerances": {
"description": "Tolerances for a parameter ",
"type": "array",
"items": {
"description": "Entity to express the tolerances of a parameter",
"type": "object",
"properties": {
"lowerLimit": {
"description": "The lower direct limit of the tolerance",
"type": "string"
},
"upperLimit": {
"description": "Upper direct limit of the tolerance",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerLimit",
"upperLimit"
]
}
}
},
"required": [
"name",
"semanticReference",
"parameterKey"
]
}
},
"precedenceRelation": {
"description": "List of alternative process steps from which the manufacturer has to select exactly one step to be executed. In case of no alternative process step, the list features only one element. In case of the last element, the property is not used, since the process step has no successor",
"type": "array",
"items": {
"description": "List of process steps that must be executed in parallel",
"type": "object",
"properties": {
"precedenceElements": {
"description": "List process steps that must be executed in parallel",
"type": "array",
"items": {
"description": "Entity to link the current process step to its successors",
"type": "object",
"properties": {
"successor": {
"description": "List of subsequent process step which can be executed in any order ",
"type": "array",
"items": {
"type": "string"
}
}
},
"required": [
"successor"
]
}
}
},
"required": [
"precedenceElements"
]
}
},
"childProcessSteps": {
"description": "List of child processes that need to be executed to complete the parent process step. It enables the expression of hierarchies between capabilities, e.g. a transport capability needs to execute at least a pick, a move and a place capability",
"type": "array",
"items": {
"type": "string"
}
},
"processStepType": {
"description": "Distinguishes process steps based on whether there are the first or last process step to be executed, or if they are a subprocess step, which subdivides a higher-level process step into smaller process steps",
"type": "string",
"enum": [
"IsFirstElement",
"IsLastElement",
"IsProcessElement",
"IsSubprocessElement"
]
},
"capabilityId": {
"description": "Locally unique identifier for a capability.",
"type": "string"
}
},
"required": [
"processStepIdentifier",
"processStepType",
"capabilityId"
]
}
},
"productVersion": {
"description": "Version of the product whose manufacturing steps are specified with the bill of process. It can for example specify a concrete variant of a product",
"type": "string"
},
"productName": {
"description": "Name of the product whose production steps are specified within the bill of process",
"type": "string"
},
"billOfProcessIdentification": {
"description": "Unique identifier for a bill of process that can be used to reference instances of the bill of process",
"type": "string"
},
"version": {
"description": "The unique identifier of the aspect model defining the structure and the semantics of the message'\''s header. The version number should reflect the versioning schema of aspect models in Catena-X.",
"type": "string",
"pattern": "^(0|[1-9][0-9]*).(0|[1-9][0-9]*).(0|[1-9][0-9]*)(-(0|[1-9A-Za-z-][0-9A-Za-z-]*)(.[0-9A-Za-z-]+)*)?([0-9A-Za-z-]+(.[0-9A-Za-z-]+)*)?$"
}
},
"required": [
"process",
"productVersion",
"productName",
"billOfProcessIdentification",
"version"
]
}
},
"required": [
"partId",
"partName",
"generalTolerance",
"material",
"partQuantity"
]
},
"firstDeliveryDate": {
"description": "RFQ-Configuration: Date of desired, first, but not must delivery",
"type": "string",
"format": "date"
},
"lastDeliveryDate": {
"description": "RFQ-Configuration: date of required and last acceptable delivery",
"type": "string",
"format": "date"
},
"additionalComments": {
"description": "RFQ-Configuration: placeholder for any kind of additional comments",
"type": "string"
},
"additionalFiles": {
"description": "RFQ-Configuration: in case there are additional documents or files to share (like e.g. technical drawings)",
"type": "object",
"properties": {
"fileType": {
"description": "RFQ-Configuration: file format",
"type": "string"
},
"filePath": {
"description": "path or address to the file ",
"type": "string"
},
"fileName": {
"description": "name of the file",
"type": "string"
},
"fileObject": {
"description": "the file object itself, in case this could be sent via the API",
"type": "object",
"properties": {}
}
},
"required": [
"fileType",
"fileName"
]
},
"orderQuantity": {
"description": "RFQ-Configuration: quantity at all, valid for complete order (usually number of products to be ordered)",
"type": "object",
"properties": {
"quantityNumber": {
"description": "The number of objects related to the measurement unit",
"type": "number"
},
"measurementUnit": {
"description": "Unit of Measurement for the quantity of serialized objects",
"type": "string",
"pattern": "[a-zA-Z]*:[a-zA-Z]+"
}
},
"required": [
"quantityNumber",
"measurementUnit"
]
}
},
"required": [
"cadFile",
"parts",
"lastDeliveryDate",
"orderQuantity"
]
},
"rfqSender": {
"description": "all data about sender of request for quotation, important for offer and delivery",
"type": "object",
"properties": {
"senderName": {
"description": "RFQ-Sender: name of the sender",
"type": "string"
},
"senderAdress": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, address of sender",
"type": "string"
},
"senderCompanyName": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, company name of sender",
"type": "string"
},
"senderEMail": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, e-mail address of sender",
"type": "string"
},
"senderPhoneNumber": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, phone number of sender",
"type": "string"
},
"senderAccountAddress": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, address of sender for account",
"type": "string"
},
"senderDeliveryAddress": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, address of sender for delivery",
"type": "string"
},
"deliveryRequirements": {
"description": "RFQ-Sender: filled by customer, any kind of delivery requirements",
"type": "string"
}
},
"required": [
"senderName",
"senderAdress",
"senderEMail",
"senderPhoneNumber",
"senderAccountAddress",
"senderDeliveryAddress"
]
},
"cxHeader": {
"description": "header information by Catena-X",
"type": "object",
"properties": {
"messageId": {
"description": "Unique ID identifying the message. The purpose of the ID is to uniquely identify a single message, therefore it MUST not be reused.",
"type": "string",
"pattern": "(^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)|(^urn:uuid:[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)"
},
"context": {
"description": "Information about the context the message should be considered in.\nThe value MUST consist of two parts: an identifier of the context (e.g. business domain, etc.) followed by a version number.\nBoth the identifier and the version number MUST correspond to the content of the message.\nIf the content of a message is described by an aspect model available in the Catena-X Semantic Hub, then the unique identifier of this semantic model (e.g. urn:samm:io.catenax.<ASPECT-MODEL-NAME>:1.x.x) MUST be used as a value of the context field. This is considered the default case.\nIn all other cases the value of the context field MUST follow the pattern <domain>-<subdomain>-<object>:<[major] version> (e.g. TRACE-QM-Alert:1.x.x).\nVersioning only refers to major versions in both default and fallback cases.\nNote: The version of the message'\''s header is specified in the version field.",
"type": "string"
},
"sentDateTime": {
"description": "Time zone aware timestamp holding the date and the time the message was sent by the sending party. The value MUST be formatted according to the ISO 8601 standard",
"type": "string",
"pattern": "-?([1-9][0-9]{3,}|0[0-9]{3})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T(([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9](.[0-9]+)?|(24:00:00(.0+)?))(Z|(+|-)((0[0-9]|1[0-3]):[0-5][0-9]|14:00))?"
},
"senderBpn": {
"description": "The Business Partner Number of the sending party. The value MUST be a valid BPN. BPNA and BPNS are not allowed. Applicable constraints are defined in the corresponding standard",
"type": "string",
"pattern": "^BPNL[a-zA-Z0-9]{12}$"
},
"receiverBpn": {
"description": "The Business Partner Number of the receiving party. The value MUST be a valid BPN. BPNA and BPNS are not allowed. Applicable constraints are defined in the corresponding standard.",
"type": "string",
"pattern": "^BPNL[a-zA-Z0-9]{12}$"
},
"expectedResponseBy": {
"description": "Time zone aware timestamp holding the date and time by which the sending party expects a certain type of response from the receiving party. The meaning and interpretation of the fields'\''s value are context-bound and MUST therefore be defined by any business domain or platform capability making use of it. The value MUST be formatted according to the ISO 8601 standard",
"type": "string",
"pattern": "-?([1-9][0-9]{3,}|0[0-9]{3})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T(([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9](.[0-9]+)?|(24:00:00(.0+)?))(Z|(+|-)((0[0-9]|1[0-3]):[0-5][0-9]|14:00))?"
},
"relatedMessageId": {
"description": "Unique ID identifying a message somehow related to the current one",
"type": "string",
"pattern": "(^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)|(^urn:uuid:[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)"
},
"version": {
"description": "The unique identifier of the aspect model defining the structure and the semantics of the message'\''s header. The version number should reflect the versioning schema of aspect models in Catena-X.",
"type": "string",
"pattern": "^(0|[1-9][0-9]*).(0|[1-9][0-9]*).(0|[1-9][0-9]*)(-(0|[1-9A-Za-z-][0-9A-Za-z-]*)(.[0-9A-Za-z-]+)*)?([0-9A-Za-z-]+(.[0-9A-Za-z-]+)*)?$"
}
},
"required": [
"messageId",
"context",
"sentDateTime",
"senderBpn",
"receiverBpn",
"version"
]
}
},
"required": [
"rfqIdentification",
"rfqConfiguration",
"rfqSender",
"cxHeader"
]
}
}'
curl -L -X POST 'https://example.com/query-api/v3/:api-endpoint/request-for-quotation' \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
--data-raw '{
"filter": {
"description": "The request for quotation represents the data structure to configure a manufacturing request and send this to a supplier receive a quotation",
"type": "object",
"properties": {
"rfqIdentification": {
"description": "all properties necessary for identification of the request for quotation",
"type": "object",
"properties": {
"rfqSource": {
"description": "RFQ-Identification: digital address of the sender (e.g.token, IP address, link, user account)",
"type": "string"
},
"rfqId": {
"description": "RFQ-Identification: internal identifier in user account",
"type": "string"
},
"rfqName": {
"description": "RFQ-Identification: name for the request for user account management (usually name of the product to be manufactured)",
"type": "string"
},
"rfqDateTime": {
"description": "RFQ-Identification: date and time of the request in user account",
"type": "string",
"pattern": "-?([1-9][0-9]{3,}|0[0-9]{3})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T(([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9](.[0-9]+)?|(24:00:00(.0+)?))(Z|(+|-)((0[0-9]|1[0-3]):[0-5][0-9]|14:00))?"
},
"rfqVersion": {
"description": "RFQ-Identification: version of this request in case there were any changes",
"type": "string"
}
},
"required": [
"rfqId",
"rfqName",
"rfqDateTime",
"rfqVersion"
]
},
"rfqConfiguration": {
"description": "all information to configure a request for quotation",
"type": "object",
"properties": {
"cadFile": {
"description": "RFQ-Configuration: CAD file as geometry definition, e.g. step file",
"type": "object",
"properties": {
"fileType": {
"description": "RFQ-Configuration: file format",
"type": "string"
},
"filePath": {
"description": "path or address to the file ",
"type": "string"
},
"fileName": {
"description": "name of the file",
"type": "string"
},
"fileObject": {
"description": "the file object itself, in case this could be sent via the API",
"type": "object",
"properties": {}
}
},
"required": [
"fileType",
"fileName"
]
},
"parts": {
"description": "RFQ-Configuration: list of parts contained in the CAD file",
"type": "object",
"properties": {
"partId": {
"description": "RFQ-PartConfiguration: identifier of the part from CAD File",
"type": "string"
},
"partName": {
"description": "RFQ-PartConfiguration: name of the part in CAD file. In case the CAD file has only one part, this could also be the file name.",
"type": "string"
},
"manufacturingDomain": {
"description": "RFQ-PartConfiguration: domain of required process (e.g. subtractive manufacturing, additive manufacturing, assembly)",
"type": "string"
},
"generalTolerance": {
"description": "RFQ-PartConfiguration: selection of defined tolerance classes",
"type": "string"
},
"additionalRequirements": {
"description": "RFQ-PartConfiguration: specific requirements e.g. to guarantee quality, like premium quality check or standard quality check or test part required (makes only sense for batch)",
"type": "string"
},
"material": {
"description": "RFQ-PartConfiguration: material definition with further information",
"type": "object",
"properties": {
"materialProperties": {
"description": "material definition with additional detail properties with name, value and value type, like name= density, value=2.7, type=g/m3 or name= chemical term, value=AlMgMn, type=periodic table",
"type": "object",
"properties": {
"value": {
"description": "value to detail the part material item",
"type": "string"
},
"valueType": {
"description": "value type to specify the value of the property",
"type": "string"
},
"propertyName": {
"description": "name of the property",
"type": "string"
}
},
"required": [
"value",
"valueType",
"propertyName"
]
},
"materialFamily": {
"description": "definition of material family for preselection",
"type": "string"
}
},
"required": [
"materialProperties"
]
},
"partQuantity": {
"description": "RFQ-PartConfiguration: Quantity of which the part item is assembled into the parent item (within the CAD File). In general it is '\''1'\'' for serialized parts.",
"type": "object",
"properties": {
"quantityNumber": {
"description": "The number of objects related to the measurement unit",
"type": "number"
},
"measurementUnit": {
"description": "Unit of Measurement for the quantity of serialized objects",
"type": "string",
"pattern": "[a-zA-Z]*:[a-zA-Z]+"
}
},
"required": [
"quantityNumber",
"measurementUnit"
]
},
"billOfProcess": {
"description": "RFQ-PartConfiguration: list of process steps for part to be manufactured",
"type": "object",
"properties": {
"process": {
"description": "List that contains all manufacturing steps of a product, whereat each manufacturing step refers to exactly one capability. This list contains all process steps that are required to manufacture the product, specified with the bill of process ",
"type": "array",
"items": {
"description": "Entity to characterize single process steps",
"type": "object",
"properties": {
"processStepIdentifier": {
"description": "Unique identifier for a concrete process step",
"type": "array",
"items": {
"type": "string"
}
},
"inputParameters": {
"description": "Optional list of parameters that are required to execute the corresponding process step",
"type": "array",
"items": {
"description": "Generic entity to characterize parameters. It distinguished four cases: a parameter without a value, a parameter with a value, a parameter with a value range and a parameter with tolerances ",
"type": "object",
"properties": {
"name": {
"description": "Name of the parameter",
"type": "string"
},
"value": {
"description": "Value of the parameter",
"type": "string"
},
"semanticReference": {
"description": "Reference to a semantic namespace in which the type of the parameter is defined",
"type": "array",
"items": {
"type": "string"
}
},
"parameterKey": {
"description": "Enumeration that is used to distinguish whether the parameter has no value, has a value, has a value range or has a value with tolerances",
"type": "string",
"enum": [
"HasValue",
"HasNoValue",
"HasValueRange",
"HasTolerances"
]
},
"valueRangeList": {
"description": "List with value ranges for a parameter",
"type": "array",
"items": {
"description": "Entity for each value range item",
"type": "object",
"properties": {
"lowerValue": {
"description": "Lower border of a value range item",
"type": "string"
},
"upperValue": {
"description": "Upper border for a value range item",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerValue",
"upperValue"
]
}
},
"tolerances": {
"description": "Tolerances for a parameter ",
"type": "array",
"items": {
"description": "Entity to express the tolerances of a parameter",
"type": "object",
"properties": {
"lowerLimit": {
"description": "The lower direct limit of the tolerance",
"type": "string"
},
"upperLimit": {
"description": "Upper direct limit of the tolerance",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerLimit",
"upperLimit"
]
}
}
},
"required": [
"name",
"semanticReference",
"parameterKey"
]
}
},
"outputParameters": {
"description": "Optional list of parameters that are returned from the process step and can be used as inputParameters for subsequent steps",
"type": "array",
"items": {
"description": "Generic entity to characterize parameters. It distinguished four cases: a parameter without a value, a parameter with a value, a parameter with a value range and a parameter with tolerances ",
"type": "object",
"properties": {
"name": {
"description": "Name of the parameter",
"type": "string"
},
"value": {
"description": "Value of the parameter",
"type": "string"
},
"semanticReference": {
"description": "Reference to a semantic namespace in which the type of the parameter is defined",
"type": "array",
"items": {
"type": "string"
}
},
"parameterKey": {
"description": "Enumeration that is used to distinguish whether the parameter has no value, has a value, has a value range or has a value with tolerances",
"type": "string",
"enum": [
"HasValue",
"HasNoValue",
"HasValueRange",
"HasTolerances"
]
},
"valueRangeList": {
"description": "List with value ranges for a parameter",
"type": "array",
"items": {
"description": "Entity for each value range item",
"type": "object",
"properties": {
"lowerValue": {
"description": "Lower border of a value range item",
"type": "string"
},
"upperValue": {
"description": "Upper border for a value range item",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerValue",
"upperValue"
]
}
},
"tolerances": {
"description": "Tolerances for a parameter ",
"type": "array",
"items": {
"description": "Entity to express the tolerances of a parameter",
"type": "object",
"properties": {
"lowerLimit": {
"description": "The lower direct limit of the tolerance",
"type": "string"
},
"upperLimit": {
"description": "Upper direct limit of the tolerance",
"type": "string"
},
"name": {
"description": "Name of the parameter",
"type": "string"
}
},
"required": [
"lowerLimit",
"upperLimit"
]
}
}
},
"required": [
"name",
"semanticReference",
"parameterKey"
]
}
},
"precedenceRelation": {
"description": "List of alternative process steps from which the manufacturer has to select exactly one step to be executed. In case of no alternative process step, the list features only one element. In case of the last element, the property is not used, since the process step has no successor",
"type": "array",
"items": {
"description": "List of process steps that must be executed in parallel",
"type": "object",
"properties": {
"precedenceElements": {
"description": "List process steps that must be executed in parallel",
"type": "array",
"items": {
"description": "Entity to link the current process step to its successors",
"type": "object",
"properties": {
"successor": {
"description": "List of subsequent process step which can be executed in any order ",
"type": "array",
"items": {
"type": "string"
}
}
},
"required": [
"successor"
]
}
}
},
"required": [
"precedenceElements"
]
}
},
"childProcessSteps": {
"description": "List of child processes that need to be executed to complete the parent process step. It enables the expression of hierarchies between capabilities, e.g. a transport capability needs to execute at least a pick, a move and a place capability",
"type": "array",
"items": {
"type": "string"
}
},
"processStepType": {
"description": "Distinguishes process steps based on whether there are the first or last process step to be executed, or if they are a subprocess step, which subdivides a higher-level process step into smaller process steps",
"type": "string",
"enum": [
"IsFirstElement",
"IsLastElement",
"IsProcessElement",
"IsSubprocessElement"
]
},
"capabilityId": {
"description": "Locally unique identifier for a capability.",
"type": "string"
}
},
"required": [
"processStepIdentifier",
"processStepType",
"capabilityId"
]
}
},
"productVersion": {
"description": "Version of the product whose manufacturing steps are specified with the bill of process. It can for example specify a concrete variant of a product",
"type": "string"
},
"productName": {
"description": "Name of the product whose production steps are specified within the bill of process",
"type": "string"
},
"billOfProcessIdentification": {
"description": "Unique identifier for a bill of process that can be used to reference instances of the bill of process",
"type": "string"
},
"version": {
"description": "The unique identifier of the aspect model defining the structure and the semantics of the message'\''s header. The version number should reflect the versioning schema of aspect models in Catena-X.",
"type": "string",
"pattern": "^(0|[1-9][0-9]*).(0|[1-9][0-9]*).(0|[1-9][0-9]*)(-(0|[1-9A-Za-z-][0-9A-Za-z-]*)(.[0-9A-Za-z-]+)*)?([0-9A-Za-z-]+(.[0-9A-Za-z-]+)*)?$"
}
},
"required": [
"process",
"productVersion",
"productName",
"billOfProcessIdentification",
"version"
]
}
},
"required": [
"partId",
"partName",
"generalTolerance",
"material",
"partQuantity"
]
},
"firstDeliveryDate": {
"description": "RFQ-Configuration: Date of desired, first, but not must delivery",
"type": "string",
"format": "date"
},
"lastDeliveryDate": {
"description": "RFQ-Configuration: date of required and last acceptable delivery",
"type": "string",
"format": "date"
},
"additionalComments": {
"description": "RFQ-Configuration: placeholder for any kind of additional comments",
"type": "string"
},
"additionalFiles": {
"description": "RFQ-Configuration: in case there are additional documents or files to share (like e.g. technical drawings)",
"type": "object",
"properties": {
"fileType": {
"description": "RFQ-Configuration: file format",
"type": "string"
},
"filePath": {
"description": "path or address to the file ",
"type": "string"
},
"fileName": {
"description": "name of the file",
"type": "string"
},
"fileObject": {
"description": "the file object itself, in case this could be sent via the API",
"type": "object",
"properties": {}
}
},
"required": [
"fileType",
"fileName"
]
},
"orderQuantity": {
"description": "RFQ-Configuration: quantity at all, valid for complete order (usually number of products to be ordered)",
"type": "object",
"properties": {
"quantityNumber": {
"description": "The number of objects related to the measurement unit",
"type": "number"
},
"measurementUnit": {
"description": "Unit of Measurement for the quantity of serialized objects",
"type": "string",
"pattern": "[a-zA-Z]*:[a-zA-Z]+"
}
},
"required": [
"quantityNumber",
"measurementUnit"
]
}
},
"required": [
"cadFile",
"parts",
"lastDeliveryDate",
"orderQuantity"
]
},
"rfqSender": {
"description": "all data about sender of request for quotation, important for offer and delivery",
"type": "object",
"properties": {
"senderName": {
"description": "RFQ-Sender: name of the sender",
"type": "string"
},
"senderAdress": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, address of sender",
"type": "string"
},
"senderCompanyName": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, company name of sender",
"type": "string"
},
"senderEMail": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, e-mail address of sender",
"type": "string"
},
"senderPhoneNumber": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, phone number of sender",
"type": "string"
},
"senderAccountAddress": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, address of sender for account",
"type": "string"
},
"senderDeliveryAddress": {
"description": "RFQ-Sender: BPDM/ or fill in by the customer, address of sender for delivery",
"type": "string"
},
"deliveryRequirements": {
"description": "RFQ-Sender: filled by customer, any kind of delivery requirements",
"type": "string"
}
},
"required": [
"senderName",
"senderAdress",
"senderEMail",
"senderPhoneNumber",
"senderAccountAddress",
"senderDeliveryAddress"
]
},
"cxHeader": {
"description": "header information by Catena-X",
"type": "object",
"properties": {
"messageId": {
"description": "Unique ID identifying the message. The purpose of the ID is to uniquely identify a single message, therefore it MUST not be reused.",
"type": "string",
"pattern": "(^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)|(^urn:uuid:[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)"
},
"context": {
"description": "Information about the context the message should be considered in.\nThe value MUST consist of two parts: an identifier of the context (e.g. business domain, etc.) followed by a version number.\nBoth the identifier and the version number MUST correspond to the content of the message.\nIf the content of a message is described by an aspect model available in the Catena-X Semantic Hub, then the unique identifier of this semantic model (e.g. urn:samm:io.catenax.<ASPECT-MODEL-NAME>:1.x.x) MUST be used as a value of the context field. This is considered the default case.\nIn all other cases the value of the context field MUST follow the pattern <domain>-<subdomain>-<object>:<[major] version> (e.g. TRACE-QM-Alert:1.x.x).\nVersioning only refers to major versions in both default and fallback cases.\nNote: The version of the message'\''s header is specified in the version field.",
"type": "string"
},
"sentDateTime": {
"description": "Time zone aware timestamp holding the date and the time the message was sent by the sending party. The value MUST be formatted according to the ISO 8601 standard",
"type": "string",
"pattern": "-?([1-9][0-9]{3,}|0[0-9]{3})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T(([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9](.[0-9]+)?|(24:00:00(.0+)?))(Z|(+|-)((0[0-9]|1[0-3]):[0-5][0-9]|14:00))?"
},
"senderBpn": {
"description": "The Business Partner Number of the sending party. The value MUST be a valid BPN. BPNA and BPNS are not allowed. Applicable constraints are defined in the corresponding standard",
"type": "string",
"pattern": "^BPNL[a-zA-Z0-9]{12}$"
},
"receiverBpn": {
"description": "The Business Partner Number of the receiving party. The value MUST be a valid BPN. BPNA and BPNS are not allowed. Applicable constraints are defined in the corresponding standard.",
"type": "string",
"pattern": "^BPNL[a-zA-Z0-9]{12}$"
},
"expectedResponseBy": {
"description": "Time zone aware timestamp holding the date and time by which the sending party expects a certain type of response from the receiving party. The meaning and interpretation of the fields'\''s value are context-bound and MUST therefore be defined by any business domain or platform capability making use of it. The value MUST be formatted according to the ISO 8601 standard",
"type": "string",
"pattern": "-?([1-9][0-9]{3,}|0[0-9]{3})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T(([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9](.[0-9]+)?|(24:00:00(.0+)?))(Z|(+|-)((0[0-9]|1[0-3]):[0-5][0-9]|14:00))?"
},
"relatedMessageId": {
"description": "Unique ID identifying a message somehow related to the current one",
"type": "string",
"pattern": "(^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)|(^urn:uuid:[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$)"
},
"version": {
"description": "The unique identifier of the aspect model defining the structure and the semantics of the message'\''s header. The version number should reflect the versioning schema of aspect models in Catena-X.",
"type": "string",
"pattern": "^(0|[1-9][0-9]*).(0|[1-9][0-9]*).(0|[1-9][0-9]*)(-(0|[1-9A-Za-z-][0-9A-Za-z-]*)(.[0-9A-Za-z-]+)*)?([0-9A-Za-z-]+(.[0-9A-Za-z-]+)*)?$"
}
},
"required": [
"messageId",
"context",
"sentDateTime",
"senderBpn",
"receiverBpn",
"version"
]
}
},
"required": [
"rfqIdentification",
"rfqConfiguration",
"rfqSender",
"cxHeader"
]
}
}'